C语言入门 Day_14 for循环

前言

我们定义了一个数组以后,要使用(读取或者修改)数组元素的话,可以一个一个的读取,就前两课学的那样,代码类似这个结构。

int number_list[5]={1,2,3,4,5};
printf("%d\n",number_list[0]);
printf("%d\n",number_list[1]);
printf("%d\n",number_list[2]);
printf("%d\n",number_list[3]);
printf("%d\n",numebr_list[4]);

假如我们对一个有10000个元素的数组,挨个打印输出他们的元素呢,难不成还要写一万行printf()?

这显然是不现实的。这种代码太多了,很容易出错,也很难维护。

这时候我们就要引入一种新的机制——循环,它可以按照我们意愿,反复执行同样的代码,直到满足边界条件

循环就像是一个没有感情的机器人,我们可以让它执行重复的枯燥的工作,当然这个工作需要步骤清晰。

比如图中1,打开抽屉;2,取出物品;3,关上抽屉。这三个动作重复但清晰,机器人会重复执行它们,直到取完所有抽屉里面的物品。

C语言中有多种循环的机制,我们今天学习第一种循环——for循环

1.for循环

1.1

自然界中,一直重复的四季更替,昼夜交替,阴晴圆缺叫做循环

在程序中,满足条件的情况下,反复执行同一段代码就叫做循环

下面代码会循环打印变量a的值,一共打印五次:

for(int a=0;a<5;a=a+1)
{printf(“变量的值是%d\n”,a);
}

1.for循环的语法格式——循环条件部分   for( int a = 0; a < 5; a = a + 1 )

2.for循环的代码块   {   printf("变量a的值是%d\n", a);   }

3.for循环的关键字——for

for(int a=0;a<5;a=a+1)
{printf(“变量的值是%d\n”,a);
}

4.for循环中的第一部分,初始定义    int a = 0

5.for循环中的第二部分,循环判断的条件   a<0

6.for循环中的第三部分,迭代操作  a=a+1

1.2

for(;;)

for循环的循环条件部分被两个分号分隔成了三个部分,它们分别是:

初始定义,循环判断条件,迭代操作

for循环的条件中,第一部分是在第一个分号之前,我们叫做初始定义;

比如这里定义了变量a,int a = 0 。

1.3

我们来填写一个for循环的判断条件中的初始定义int b = 10

for(int b=10;b<20;b++);

for循环的条件中,第二部分是在第一个分号之后,第二个分号之前,我们叫做循环的判断条件;

比如这里判断a < 5是否为真,如果为真,就执行循环中的代码块;如果为假就结束循环。

1.4

最后一部分是第二个分号之后的部分,是迭代动作,也是决定了要循环几次的地方;

如果没有变量的迭代动作,可能循环的判断条件永远为真,这就变成了无限循环或者死循环;

如果一次迭代动作是给变量增加5,那可能循环的判断条件只有第一次为真,迭代一次以后就为了,也就不再执行了。

填写for循环中的第三部分迭代操作b++

for(int b=10;b<20;b++);

同样是给变量增加1,我们一次使用了a = a + 1

一次使用了自增符号b++,两者效果是一样的。

1.5

for循环的代码块,和判断一样,for循环的代码块也是被花括号括起来的,只要判断条件符合,就会执行这个代码块。

我们来填入循环的代码块,打印b的值printf("b的值是%d\n", b);

for(int b = 10; b < 15; b++)
{printf("b的值是%d\n", b);
}

打印结果

10
11
12
13
14

 

1.6

for循环里面,第一部分是初始定义,定义变量的值;

第二部分是循环的判断条件,为真就执行代码块,为假就不执行;

第三部分是迭代动作,用以控制循环的执行次数

 

1.7

有了for循环,我们就可以让代码帮我们做哪些枯燥单调的重复动作了。比如我们就可以告诉机器人:

1,从第一个格子开始;

2,格子数小于9之前,都取出格子里的东西;

3,每次格子数增加1。

同时就像判断一样,我们也可以看到,循环的代码执行顺序,和顺序执行,条件执行,也是不一样的。

顺序执行是从上到下

条件执行是根据判断条件,只执行一部分分支的代码,但只会执行一次

循环执行则是会反复执行同一部分的代码。

2.循环执行顺序

2.1

计算机是个一板一眼的家伙,我们写出来的代码它都会默认按照从上到下的顺序执行。

比如这里的顺序执行:

int a=1;
int b=2;
int c=3;
printf("a的值是%d\n",a);
printf("b的值是%d\n",b);
printf("c的值是%d\n",c);

1.执行第一行  int a = 1;

2.执行第二行  int b = 2;

3.执行第三行  int c = 3;

int a=1;
int b=2;
int c=3;
printf("a的值是%d\n",a);
printf("b的值是%d\n",b);
printf("c的值是%d\n",c);

4.执行第四行  printf("a的值%d\n", a);

5.执行第五行  printf("b的值%d\n", b);

6.执行第六行  printf("c的值%d\n", c);

2.2

以及if-else判断语句中的选择执行,只执行某一个判断分支。

这里的判断语句只执行else分支:

int a=5;
if(a>5){printf("大于五\n");
}
else{printf("小于等于五\n");
}

然后我们来看看循环的代码执行顺序:

循环会反复执行代码块中的代码,直到循环条件不满足。

int number_list[5]={1,2,3,4,5};
for{int count=0;count<5;count++};{printf("%d\n",int numbrt_list[count])
}

1.执行的第一行,定义一个整形数组并赋值   int number_list[5] = {1, 2, 3, 4, 5}

2.for循环开始进行判断,判断为真,执行代码块的代码  for(int count = 0; count < 5; count++)

3.第一次执行代码块,用count变量直接当做数组下标使用  printf("%d\n", number_list[count]

4.第二次循环条件的判断  for(int count = 0; count < 5; count++)

5.第二次执行代码块,数组下标为1  printf("%d\n", number_list[count])

……

12. 第六次判断循环条件,count是5,判断条件count < 5不成立,终止循环

2.3

可以看到循环的代码执行特点

循环判断条件符合的时候,会反复执行代码块中的代码。

细到for循环里面也有小的执行顺序之分:

int number_list[5]={1,2,3,4,5};
for(int count=0;count<5;count++){printf("%d\n",number_list[count]);
}

1.执行到for循环

2.只有第一次才执行初始定义,也就是这里的定义一个变量  int count = 0

3.循环开始以后,先执行循环的判断条件  int number_list[5] = {1, 2, 3, 4, 5};

4.再执行代码块中的代码  printf("%d\n", number_list[count])

5.最后执行迭代操作的自增 count++

所以在for循环内部,首先执行初始条件的定义,这只会执行一次;

然后进行循环条件的判断,判断为真,执行代码块中的代码;

最后执行迭代操作

2.4

对于写代码和阅读代码的人来说,循环执行顺序的难点就已经不是代码的写法了,

而是循环中的代码块到底要执行几次,在什么条件下终止循环

我们去看需要执行几次循环中的代码块这件事情,一般都是自己心算一下或者用笔计算一下,有个大致的判断,以保证代码按照我们的需求来正确执行

同时循环和判断的代码块也是一样的,代码块中的代码作为一个整体,统一顺序执行,不能够分割出来;

所以也会用到花括号{}来定义代码块。

同时我们这里也应用了自增运算符,i++,来做迭代操作,这也是自增运算符最重要的应用场景

2.5

同时,我们用for循环,对数组中的每个元素进行了一次访问,我们就说完成了一次遍历

遍历是指对一个数组中的所有元素进行访问的操作。

3.易错点

 初始变量的定义也可以先在for循环外进行;

for(;;)会造成程序的死循环(无限循环),永远停不下来的循环。

4.思维导图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/99629.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Bootstrap的行、列布局设计(网络系统设计)

目录 00-基础知识01-等宽列布局02-指定某一列的宽度03-根据内容自动改变列的宽度04-五种预定义列宽度 .col、.col-sm-*、.col-md-*、.col-lg-*、.col-xl-*05-不同视口宽度按不同的分列方案划分06-删除列内容的盒模型的外边距07-超过12列怎么办&#xff1f;08-重新排列各列的顺序…

Bootstrap的标题类(标题样式h1~h6)

Bootstrap 的标题字体大小通常遵循以下样式规则&#xff1a; h1 标题的字体大小为 2.5rem&#xff08;40像素&#xff09;。h2 标题的字体大小为 2rem&#xff08;32像素&#xff09;。h3 标题的字体大小为 1.75rem&#xff08;28像素&#xff09;。h4 标题的字体大小为 1.5re…

大数据的关键技术之——大数据采集

大数据的关键技术之——大数据采集 本文目录&#xff1a; 一、写在前面的话 二、大数据采集概念 三、大数据采集步骤 3.1、大数据采集步骤&#xff08;总体角度&#xff09; 3.2、大数据采集步骤&#xff08;数据集角度&#xff09; 3.3、大数据采集步骤&#xff08;数据…

O2OA(翱途)开发平台 V8.1正式发布

尊敬的O2OA(翱途)平台合作伙伴、用户以及亲爱的开发小伙伴们&#xff0c;平台 V8.1版本已正式发布。正值8月的最后一周&#xff0c;我们以更安全、更高效、更好用的崭新面貌迎接9月的到来。 O2OA开发平台v8.1版本更注重于对系统级别的安全防护。其中重大的更新&#xff0c;是对…

解决VUE3项目部署后存在缓存页面不更新的问题

方法一&#xff1a; 找到项目中的index.html文件&#xff0c;在头部加上以下代码 <meta http-equiv"Pragma" content"no-cache"> <meta http-equiv"Cache-control" content"no-cache"> <meta http-equiv"Cache&…

LeetCode 138. Copy List with Random Pointer【链表,DFS,迭代,哈希表】中等

本文属于「征服LeetCode」系列文章之一&#xff0c;这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁&#xff0c;本系列将至少持续到刷完所有无锁题之日为止&#xff1b;由于LeetCode还在不断地创建新题&#xff0c;本系列的终止日期可能是永远。在这一系列刷题文章…

【开发问题系列】CSV转Excel

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…

MySQL5.7慢查询实践

总结 获取慢查询SQL 已经执行完的SQL&#xff0c;检查慢查询日志&#xff0c;日志中有执行慢的SQL正在执行中的SQL&#xff0c;show proccesslist;&#xff0c;结果中有执行慢的SQL 慢查询日志关键参数 名称解释Query_time查询消耗时间Time慢查询发生时间 分析慢查询SQL e…

python基础运用例子

python基础运用例子 1、⼀⾏代码交换 a , b &#xff1a;a, b b, a2、⼀⾏代码反转列表 l[::-1]3、合并两个字典 res {**dict1, **dict2}**操作符合并两个字典for循环合并dict(a, **b) 的方式dict(a.items() b.items()) 的方式dict.update(other_dict) 的方式 4、⼀⾏代码列…

蓝桥杯打卡Day2

文章目录 糖果分享游戏玛雅人的密码 一、糖果分享游戏IO链接 本题思路:本题是一道模拟题&#xff0c;最终需要每个人得到相同的糖果&#xff0c;那么此时我们开辟一个数组用来保存每个人分一半的结果&#xff0c;然后每个人都需要从左边拿到对方糖果&#xff0c;那么左边就是…

iPhone 15 Pro展示设计:7项全新变化呈现

我们不应该再等iPhone 15 Pro在苹果9月12日的“Wonderlust”活动上发布了&#xff0c;而且可能会有很多升级。有传言称&#xff0c;iPhone 15 Pro将是自iPhone X以来最大的飞跃&#xff0c;这要归功于大量的新变化&#xff0c;从带有更薄边框的新钛框架到顶级A17仿生芯片和动作…

SPI协议

文章目录 前言一、简介1、通信模式2、总线定义3、SPI通信结构4、SPI通讯时序5、SPI数据交互过程 二、多从机模式1、多NSS2、菊花链3、SPI通信优缺点4、UART、IIC、SPI 区别 三、总结四、参考资料 前言 SPI协议是我们的重要通信协议之一&#xff0c;我们需要掌握牢靠。 一、简介…