问题描述:
#include<stdio.h>
void main()
{
int x=5,y;
y=++x*++x;
printf("%d\n",y);
}
这个结果是49
#include<stdio.h>
void main()
{
float x=1,y;
y=++x*++x;
printf("%f\n",y);
}
这个是6.000000
不是一样的吗 为什么不一样
看来你们没懂我的意思 要么是49 9 要么是42 6可是为什么是49 6
问题解答:
这个没什么好讨论的,TC就是这样的结果
换VC就会发现另外一个结果
在一个表达式中对一个变量的多次自增(增减)操作,其运算结果依赖编译器的实现方式
显然,这里TC对int 和 float 采取了不同的法则
第一个程序x=5,而第二个程序x=1
结果当然不一样啦。
当然不一样啊
一个是%d 是以十进制形式输出
%f 是输出单精度型 默认6位小数
我明白你的意思是什么,你不清楚的是这里y=++x*++x这个运算,因为++的优先级在*之上,所以先进行两次自增才进行乘运算,而++在x前,所以每自增一次都要存回x,所以连续进行两次,*的两边都相当于自增两次,所以是7*7=49,后一个同理