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++的一些我个人得出的见解,如果有缺漏或者错误,欢迎各位指出。

相关推荐
隔窗听雨眠18 小时前
C语言函数递归从入门到精通(下):性能优化与工程实践
c语言·算法·性能优化
退休倒计时18 小时前
【每日一题】LeetCode 146. LRU 缓存 TypeScript
算法·leetcode·缓存·typescript
珊瑚里的鱼18 小时前
【递归】汉诺塔
算法·深度优先
MrZhao40018 小时前
一个最小 Agent 是怎么跑起来的:Agent Loop 与工具使用全链路
算法
Keven_1118 小时前
算法札记:二分
算法·二分
TCW112118 小时前
AI底层系列:用C++实现线性代数的公式推导与算法设计-6.线性方程组的解集
c++·人工智能·算法
luoyayun36118 小时前
从零实现 EBU R128 LUFS 响度分析:K-weighting 滤波、双门限算法
算法·lufs响度分析
小糯米60118 小时前
JS 数组
数据结构·算法·排序算法
小欣加油18 小时前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
拳里剑气19 小时前
C++算法:链表
c++·算法·链表