【编程基础】C语言循环语句解析

循环语句是一种很重要的结构,这种结构的特点就是在某种条件下,会重复循环执行某一段代码,直到条件不成立为止。这里的条件称为循环条件,重复执行的那段代码称为循环体。

其实不只是C语言有循环语句,几乎所有语言都有循环语句,大家可以想象要做同样一件事情十万次,要是没有循环会多么痛苦!

C语言可以构成循环语句的有如下几种:

1、goto语句和if语句组成; 2、while语句; 3、do while语句; 4、for语句;

goto-if循环语句

goto和if组成的语句最为灵活,但是也最没有结构化,当出现复杂情况时不好维护,因此在实际代码中很少出现,也不鼓励使用,几乎用这种组成的循环都可以用后面三种完成。比如计算1到100之和:

int i = 1, sum = 0; loop: if (i <= 100) { sum += i; i++; goto loop: }

while循环语句

while语句一般形式是:

while (逻辑表达式) { ... }

执行时首先执行逻辑表达式,如果表达式为真值,则执行括号内的循环体,如果循环体只有一条语句,可以不加大括号。执行一次循环体后,再次判断逻辑表达式是否为真,并重复这个过程,直到某次逻辑表达式为假时才会直接跳到循环体之后的语句继续往下执行。

在编写一个任务函数时会常常用这种形式的while循环,比如某一个永久执行的线程函数体可能有如下的形式:

while (1) { ... }

用while改写上面的求和代码如下:

int i = 1, sum = 0; while (i++ <= 100) { sum += i; }

do while循环语句

这种循环的一般形式为:

do { ... } while (逻辑表达式);

这种循环跟上面基本一样,唯一的差别就是首先无条件的先执行一次循环体后再判断逻辑表达式的值,然后根据这个值决定是否继续循环体,真则继续,假则不再循环,接着执行后面的语句。用do while语句改写上面的求和代码如下:

int i = 1, sum = 0; do { sum += i; } while (i++ <= 100);

for循环语句

for语句的一般形式为:

for (表达式1; 逻辑表达式2; 表达式3) { ... }

它的执行过程如下: 1> 求解表达式1。 2> 求解逻辑表达式2,若为真值,则执行循环体,然后进入第3步;若其值为假,则跳转到第5步。 3> 求解表达式3。 4> 转回上面第2步继续执行。 5> 执行for语句循环体下面的语句。

由于表达式1只是在开始执行一次,因此常常用于初始化一些变量。表达式2就是控制是否继续循环的条件,表达式3一般是循环中的一些数据变化和数据增量。三个表达式都可以不要,但必须保留分号(;)作为语法错误检查。但是如果表达式2没有设置,则默认为永远是真值。

用for语句修改上面的求和代码如下:

int i; sum; for (i=1,sum=0; i<=100; i++) { sum += i; }

这个也可以跟简单写成如下的样子: for (i=1,sum=0; i<=100; sum+=i,i++); 这里把求和部分也放到表达式3里面去了。

C语言的循环语句一共就这些,相信把每一个都仔细理解了,还是比较好掌握。

原文发布于微信公众号 - 程序员互动联盟(coder_online)

原文发表时间:2015-09-19

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏数据结构与算法

06:整数奇偶排序

06:整数奇偶排序 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB描述 给定10个整数的序列,要求对其重新排序。排序要求: 1...

41460
来自专栏小樱的经验随笔

C/C++中连接函数strcat的应用(简单讲解)

有位学弟问到我如何将两个字符连接起来,想想java/python里面可以直接用+连接起来,可是C/C++里面有没有这么方便的做法呢?

12220
来自专栏五分钟学算法

五分钟看懂一个高难度的排序:堆排序

堆是具有以下性质的完全二叉树:每个结点的值都大于或等于其左右孩子结点的值,称为大顶堆;或者每个结点的值都小于或等于其左右孩子结点的值,称为小顶堆。

11420
来自专栏Python小屋

妙用Python内置函数int()快速计算等比数列前n项和

本文要点在于Python内置函数int()的用法,所以计算等比数列前n项和时没有使用数学上的公式Sn=a1*(1-q^n)/(1-q)。 一般遇到这样的问题,很...

71760
来自专栏小小挖掘机

各种排序算法的分析及java&python实现

排序大的分类可以分为两种:内排序和外排序。在排序过程中,全部记录存放在内存,则称为内排序,如果排序过程中需要使用外存,则称为外排序。下面讲的排序都是属于内排序。...

40670
来自专栏武培轩的专栏

排序算法-冒泡排序

算法简介 冒泡排序(Bubble Sort)是一种典型的交换排序算法,持续比较相邻元素,大的挪到后面,因此大的会逐步往后挪,故称之为冒泡。 算法描述 比较相邻的...

36170
来自专栏恰童鞋骚年

剑指Offer面试题:13.调整数组顺序使奇数位于偶数前面

  例如有以下一个整数数组:12345,经过调整后可以为:15342、13542、13524等等。

12260
来自专栏noteless

[一]基础类型概述

https://docs.oracle.com/javase/tutorial/java/nutsandbolts/datatypes.html

14030
来自专栏机器学习和数学

[编程经验]Python中的Lambda,Map, Reduce小结

今天要和大家分享的是Python匿名函数(anonymous functions),也叫lambda函数。匿名函数的意思就是说这个函数没有显式的函数名,因为一般...

33750
来自专栏和蔼的张星的图像处理专栏

156. 合并区间先排序再处理

给出若干闭合区间,合并所有重叠的部分。 样例 给出的区间列表 => 合并后的区间列表:

20230

扫码关注云+社区

领取腾讯云代金券