【编程基础】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 条评论
登录 后参与评论

相关文章

来自专栏小樱的经验随笔

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

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

922
来自专栏积累沉淀

JavaScript面向对象与原型

javaScript有两种开发模式:1.函数式(过程化),2.面向对象(OOP)。面向对象的语言有一个标志,那就是类的概念,而通过类可以创建任意多个具有相同属性...

21210
来自专栏五分钟学算法

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

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

1022
来自专栏恰同学骚年

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

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

1026
来自专栏武培轩的专栏

排序算法-冒泡排序

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

3427
来自专栏五分钟学算法

五分钟弄懂有点难度的排序:堆排序

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

1254
来自专栏web前端教室

js数组去重的思路与缓动公式

前端开发的面试中,至少有一类题是必出的,那就是去重。什么叫去重呢?就是把一组字符串中重复出现的,都删除掉。 这种题重要的是解决的思路要正确,思路正确的话其实也很...

2088
来自专栏技术沉淀

Python: 函数式编程

1564
来自专栏Python小屋

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

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

4626
来自专栏noteless

[一]基础类型概述

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

1003

扫码关注云+社区