x++、++x的一些问题

x++、++x在字面上无非就说一个先前置递增然后再运算,另一个是运算完再递增,是不是有些许模棱两可的感觉,接下来引用一个简单的for循环就能够大致理解:

先是x++:

	int i=0,x=0;
	for(i=0;(i++)<5;)
	{
		x+=i;
		printf("%d\n",x);
	}

这里i=0,进入for循环,会先判断(i++)是否小于5,i=0时,也即(i++)为=0,当执行完(i++)<5这条语句的判断后,才会将i++等于1。

如此,第二次,判断1<5,x为=1+2;第三次判断2<5 。 。 。第五次4<5,x=1+2+3+4+5;直至第六次5<5时,判断为False,跳出for循环。

结果是:

1
3
6
10
15

再对比一下++x:

	int i=0,x=0;
	for(i=0;(++i)<5;)
	{
		x+=i;
		printf("%d\n",x);
	}

这里第一次判断i=0,++i就为1,也即1<5,x=1;第二次i=1,2<5;第三次i=2,3<5;第四次i=3,4<5;

第五次i=4,5<5跳出循环,所以循环相比x++少执行了一次。

结果是:

1
3
6
10

接下稍微深一点的例子:

#define s(x) ((x)*(x))
int main(){
	int x=10;
	x=s(++x);
	printf("%d",x);
	return 0;
}

猜测一下,最终打印出的值会是多少。

首先来分析一下,上述代码用了一个宏定义来实现一个简单的平方函数。

实际上带入进x=s(++x)就等价于,x=((++x)*(++x)),这样你是否有头绪能够猜出最终打印的值呢。

结果是144。

是的就是144,实际上在该式子中x=((++x)*(++x)),从左到右执行了两次++x的操作,也即:

(++x)*(++x)等价于(x+2)*(x+2),也即12*12=144。

同样的进行x++的操作在执行一遍:

#define s(x) ((x)*(x))
int main(){
	int x=10;
	x=s(x++);
	printf("%d",x);
	return 0;
}

你是否能够猜出答案。

还是先分析一下代码,跟前面不同,他的等价代码的先运算后加,x=((x++)*(x++))。

这就需要按从左往右一步一步进行分析,可以用下图来描述:

所以答案是10*11=110,你猜出来了吗。

同样可以验证一下,在执行完两次x++后的值为12,可以在该代码中加上+x:

#define s(x) ((x)*(x))
int main(){
	int x=10;
	x+=s(x++);
	printf("%d",x);
	return 0;
}

结果为110+12.也即122。

以上就是++x和x++的一些我个人得出的见解,如果有缺漏或者错误,欢迎各位指出。

相关推荐
Fabian!5 分钟前
代码随想录训练营Day29 | 93.复原IP地址 | 78.子集 | 90.子集II
算法
冰淇淋加点糖24 分钟前
C语言之扫雷小游戏(完整代码版)
c语言·前端·算法
luthane41 分钟前
python 实现贪婪合并排序算法
python·算法·排序算法
3D打印技术参考1 小时前
激光增材制造新突破:精细调控NiTi合金弹热效应,实现制冷定制
人工智能·算法·计算机视觉·制造
专利爱好者小米粥1 小时前
如何成为专利检索高手?
物联网·算法·microsoft·区块链·数据库架构
通信仿真实验室2 小时前
(19)MATLAB使用Nakagami 分布对象生成Nakagami-m分布
开发语言·算法·matlab
白白白白白kkk2 小时前
【力扣算法题】每天一道,健康生活
算法·leetcode
zsyzClb2 小时前
[NOI2022] 二次整数规划问题
算法
硕风和炜3 小时前
【LeetCode: 134. 加油站 | 贪心算法】
java·算法·leetcode·贪心算法
sjsjs114 小时前
【动态规划-最长公共子序列(LCS)】力扣97. 交错字符串
算法·leetcode·动态规划