C语言自增(++)和自减(--)

简介: 对于自增自减的相关用法

一个整数类型的变量自身加 1 可以这样写:

14.png

或者

1.png

不过,C语言还支持另外一种更加简洁的写法,就是:

2.png

或者

3.png

这种写法叫做自加自增,意思很明确,就是每次自身加 1。

相应的,也有 a----a,它们叫做自减,表示自身减 1。

++-- 分别称为自增运算符自减运算符,它们在循环结构中使用很频繁。

自增和自减的示例:

4.png

自增自减完成后,会用新值替换旧值,将新值保存在当前变量中。


自增自减的结果必须得有变量来接收,所以自增自减只能针对变量,不能针对数字,例如 10++就是错误的。


需要重点说明的是,++ 在变量前面和后面是有区别的:

  • ++ 在前面叫做前自增(例如 ++a)。前自增先进行自增运算,再进行其他操作。
  • ++ 在后面叫做后自增(例如 a++)。后自增先进行其他操作,再进行自增运算。

自减(–)也一样,有前自减和后自减之分。


下面的例子能更好地说明前自增(前自减)和后自增(后自减)的区别:

5.png


a、b、c、d 的输出结果相信大家没有疑问,下面重点分析 a1、b1、c1、d1:

1.对于 a1=++a,先执行 ++a,结果为 11,再将 11 赋值给 a1,所以 a1 的最终值为11。而 a 经过自增,最终的值也为 11。


2.对于b1=b++,b 的值并不会立马加 1,而是先把 b 原来的值交给 b1,然后再加 1。b 原来的值为 20,所以 b1 的值也就为 20。而 b 经过自增,最终值为 21。


3.对于c1=--c,先执行 --c,结果为 29,再将 29 赋值给c1,所以 c1 的最终值为 29。而 c 经过自减,最终的值也为 29。


4.对于d1=d--,d 的值并不会立马减 1,而是先把 d 原来的值交给 d1,然后再减 1。d 原来的值为 40,所以 d1 的值也就为 40。而 d 经过自减,最终值为 39。

  • 可以看出:a1=++a; 会先进行自增操作,再进行赋值操作;
  • b1=b++; 会先进行赋值操作,再进行自增操作。c1=--c;d1=d--; 也是如此。

为了强化记忆,我们再来看一个自增自减的综合示例:

6.png


我们来分析一下:

       1.执行语句①时,因为是后自减,会先进行 a-b 运算,结果是 11,然后 b 再自减,就变成了 0;最后再将 a-b 的结果(也就是11)交给 c,所以 c 的值是 11。


       2.执行语句②之前,b 的值已经变成 0。对于d=(++a)-(--b),a 会先自增,变成 13,然后 b 再自减,变成 -1,最后再计算 13-(-1) ,结果是 14,交给 d,所以 d 最终是 14。

我再给读者加一个,C++ 的程序示例:

示例一:

7.png

示例二:

8.png

不管是自增运算符,还是自减运算符,它们只能作用于可变左值,而不能表达式,如下:

9.png

目录
相关文章
|
4月前
|
C语言
初识C语言:自增与自减陷阱
初识C语言:自增与自减陷阱
|
C语言
C语言运算符——自增与自减
自增与自减 一个整数类型的变量自身加 1 可以这样写: a = a + 1;或者a += 1;不过,C语言还支持另外一种更加简洁的写法,就是:a++;或者++a;这种写法叫做自加或自增,意思很明确,就是每次自身加 1。 相应的,也有a–和--a,它们叫做自减,表示自身减 1。++和–分别称为自增运算符和自减运算符,它们在循环结构中使用很频繁。
253 0
|
C语言 C++
C语言经典实例:1-10例:三角求和、显示所占字节数、自增自减运算while语句输出最小值、计算快递费用、学生成绩统计
C语言经典实例:1-10例:三角求和、显示所占字节数、自增自减运算while语句输出最小值、计算快递费用、学生成绩统计
C语言经典实例:1-10例:三角求和、显示所占字节数、自增自减运算while语句输出最小值、计算快递费用、学生成绩统计
|
C语言
宏定义可以自增自减吗?(带题讲解,并总结C语言数据类型可自加自减的)
宏定义可以自增自减吗?(带题讲解,并总结C语言数据类型可自加自减的)
348 0
宏定义可以自增自减吗?(带题讲解,并总结C语言数据类型可自加自减的)
|
C语言
C语言入门——自增,自减运算(逐行逐句分析)
C语言入门——自增,自减运算(逐行逐句分析)
340 0
C语言入门——自增,自减运算(逐行逐句分析)
|
存储 Java C语言
【C 语言】一级指针 易犯错误 模型 ( 判定指针合法性 | 数组越界 | 不断修改指针变量值 | 函数中将栈内存数组返回 | 函数间接赋值形参操作 | 指针取值与自增操作 )
【C 语言】一级指针 易犯错误 模型 ( 判定指针合法性 | 数组越界 | 不断修改指针变量值 | 函数中将栈内存数组返回 | 函数间接赋值形参操作 | 指针取值与自增操作 )
201 0
|
1月前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
62 23
|
1月前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
66 15
|
1月前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
60 24
|
1月前
|
存储 C语言
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
63 16

热门文章

最新文章