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

相关推荐
张李浩5 小时前
Leetcode 054螺旋矩阵 采用方向数组解决
算法·leetcode·矩阵
big_rabbit05025 小时前
[算法][力扣101]对称二叉树
数据结构·算法·leetcode
美好的事情能不能发生在我身上5 小时前
Hot100中的:贪心专题
java·数据结构·算法
2301_821700536 小时前
C++编译期多态实现
开发语言·c++·算法
xixihaha13246 小时前
C++与FPGA协同设计
开发语言·c++·算法
小小怪7506 小时前
C++中的函数式编程
开发语言·c++·算法
xixixiLucky7 小时前
编程入门算法题---小明爬楼梯求爬n层台阶一共多少种方法
算法
剑锋所指,所向披靡!7 小时前
数据结构之线性表
数据结构·算法
m0_672703319 小时前
上机练习第49天
数据结构·算法
样例过了就是过了9 小时前
LeetCode热题100 N 皇后
数据结构·c++·算法·leetcode·dfs·深度优先遍历