c语言关于自增自减运算符的一个问题

发布时间:2024-05-28 10:50 发布:上海旅游网

问题描述:

#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,后一个同理

热点新闻