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

相关推荐
重庆小透明10 分钟前
力扣刷题记录【1】146.LRU缓存
java·后端·学习·算法·leetcode·缓存
desssq29 分钟前
力扣:70. 爬楼梯
算法·leetcode·职场和发展
clock的时钟1 小时前
暑期数据结构第一天
数据结构·算法
小小小小王王王1 小时前
求猪肉价格最大值
数据结构·c++·算法
岁忧2 小时前
(LeetCode 面试经典 150 题 ) 58. 最后一个单词的长度 (字符串)
java·c++·算法·leetcode·面试·go
BIYing_Aurora2 小时前
【IPMV】图像处理与机器视觉:Lec13 Robust Estimation with RANSAC
图像处理·人工智能·算法·计算机视觉
martian6653 小时前
支持向量机(SVM)深度解析:从数学根基到工程实践
算法·机器学习·支持向量机
孟大本事要学习4 小时前
算法19天|回溯算法:理论基础、组合、组合总和Ⅲ、电话号码的字母组合
算法
??tobenewyorker4 小时前
力扣打卡第二十一天 中后遍历+中前遍历 构造二叉树
数据结构·c++·算法·leetcode
让我们一起加油好吗4 小时前
【基础算法】贪心 (二) :推公式
数据结构·数学·算法·贪心算法·洛谷