热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C语言编程入门之第六章C语言控制语句

  导读:本章带读者理解什么是控制语句,然后逐个讲解C语言常用的控制语句,含有控制语句的代码量多起来后就要注意写代码的风格了,本章末节都是练习题,大量的练习才能掌握好控制语句的使用

    导读:本章带读者理解什么是控制语句,然后逐个讲解C语言常用的控制语句,含有控制语句的代码量多起来后就要注意写代码的风格了,本章末节都是练习题,大量的练习才能掌握好控制语句的使用。

6.1 什么是控制语句  

    翻回第一章,当时为了讲解计算机程序,举了一个打酱油的例子:

    第一种做法:首先要准备好100块钱,然后出门要穿好衣服鞋袜,出门到便利店,拿到酱油付完钱,店家找钱,返回家中。

    可以用更加精细的描述这个行为:

    准备100块钱,或许要翻箱倒柜,直到找到100块钱才可以出门,这段时间发生的事情可以用如下语句表达:

当(还没找到100块钱的时候 == false)
{
继续找钱;
   如果(找到钱了 == true)
   {
     出门;
   }

}

  在以上语句中,当(......),如果(......),这类的控制行为用到计算机程序上就是控制语句了,因为C语言是外国人发明的,所以“当(.......)”转换成程序就是“while(......)”,“如果(......)”转换成程序就是“if(......)”。

  继续打酱油,到店里找到酱油后,店家要找钱,酱油就算30块钱好了,店家就要找还70块钱,找钱的方法为右手从钱柜里面拿钱到左手,直到左手的钱够70块钱了就结束继续拿钱,如下:

对于(开始左手没有钱; 如果左手钱够70块钱了就结束; 右手继续拿钱给左手)
{
  这段时间可以做想做的别的事;
}

 在C语言中,以上在控制语句中就为for(表达式1;表达式2;表达式3)。

 注意:每个表达式用分号;隔开。

 大致这么理解控制语句就行了,下一节就把这些控制语句用到代码上编译执行看结果。 

 

6.2 条件判断语句

6.2.1 条件判断语句if

   如果......在英文中为:if......。

   如果......那么......在英文中为:if......else...... 。

   这个就是基本的条件判断语句。代码中是这么体现的:

#include
void main()
{
int a = 3;
int b = 5;

if(a {
printf("a }

if(a > b)
{
printf("a > b 成立\n");
}
else
{
printf("a > b 不成立\n");
}
}

  运行结果为:

       a        a > b 不成立

    第一个条件控制语句中,只是判断 a 是否小于 b,如果成立就printf一段话,如果不成立继续往下执行。

      第二个条件控制语句,判断 a 是否大于 b,如果成立 printf 一段话,如果不成立 printf 另一段话。

    if和if......else...... 可以进行嵌套,如下:

#include
void main()
{
int a = 3;
int b = 5;
int c = 7;
if(a {
printf("a }

if(a > b)
{
printf("a > b 成立\n");
}
else
{
printf("a > b 不成立\n");
if(a > c)
{
printf("a > c 成立\n");
}
else
{
printf("a > c 不成立\n");
}
}
}

 

 

6.2.2 条件判断语句switch  

      switch语句与if语句的功能一样,它的作用在于更加清晰明了,适合条件判断多的情形下使用,如下:

      

#include
void main()
{
int a;

printf("请输入要查询的数字:");
scanf("%d", &a);

switch(a)
{
case 1:
printf("1 : 一心一意学程序 \n");
break;

case 2:
printf("2 : 两全其美真棒棒 \n");
break;

case 3:
printf("3 : 三心二意很不好 \n");
break;

default:
printf("您输入的数字还未加入到系统库,请重新输入 \n");
break;
}
}

  switch做的工作,就是判断传入的数值,当输入对应数值为case后面的数值的时候,执行相应语句,再执行break结束,如果没有加break语句,就会继续往下执行,读者可以除去后编译看看效果。当输入的数值没有对应的case处理,就会默认执行default里面的操作。

   一般淘宝、京东、10086、微信公众号等等都有机器人客服和人工客服,比如让客户发送1,就输出一段客户想要知道的内容,发送2,就输出另外一段,如果掌握了条件控制语句,那么恭喜你,可以做简单的机器人客服程序了,赶紧自己动手试试吧。

 

6.3 循环结构

  人生,就是一个大循环 你的起点,可能是他的终点。

       通俗点说,人每天困了睡觉,肚子饿了吃饭,尿急了上厕所。实操一下,比如小明每隔两秒钟就要尿尿,怎么用代码实现,结合之前学习,会写出以下代码:

#include
void main()
{
printf("你好,我是小明!\n");

sleep(2);
printf("尿尿 \n");
sleep(2);
printf("尿尿 \n");
sleep(2);
printf("尿尿 \n");
sleep(2);
printf("尿尿 \n");
}

  注:sleep是系统延时函数,里面传的数值就是让程序等待的秒数。 

  以上代码,只可以“尿尿”四次,那么小明要尿尿一百次呢,要一千次呢,要无限次呢?怎么做。

  这时候就要用到C语言中的循环语句了。

 

6.3.1 循环结构while

  小明每隔两秒"尿尿"十次,代码如下:

  

#include
void main()
{
int count = 0;
printf("你好,我是小明!\n");

while(1)
{
sleep(2);
printf("尿尿第%d次\n", count);

count++;

if(count == 10)
{
printf("尿完了 \n");
break;
}
}
printf("下次再战\n");
}

  以上代码中,while()括号里面的值传的是bool值,因为1永远为真,所以会无限执行,如果要验证是否无限执行,可以把代码中的“break”除去。

  在代码中的if语句里,当count等于某个数的时候执行break,就能够跳出循环了,这个数就是设定的“尿尿”次数了。

 

6.3.2 循环结构for

   总是说“尿尿”似乎不太雅,改为“吃饭”吧。以下,为for语句的例子:

#include
void main()
{
int count = 0;
printf("你好,我是小明!\n");

for(count = 0; count <10; count++)
{
sleep(2);
printf("吃饭第%d次\n", count);
}
printf("下次再战\n");
}

  for语句中,有两个分号“;”,第一个分号前写的是初始化值,让count等于0,第二个分号写的是判断值,判断count是否小于10,如果小于10就继续循环,第二个分号后面就是执行语句,count自增1。编译执行后发现,执行10次就跳出循环了。

 

  基本上会以上控制语句就够用很多了。只有大量的练习才能更好的掌握这几种语句,后续比如coutinue,goto语句等自学都能掌握了。练习题如下:

求多个整数的和及平均值

等腰直角三角形

数字金字塔

九九乘法表

三天打鱼两天晒网

黑色星期五

  如果练习有疑问可以在评论区留言。本章结束。

 



推荐阅读
  • C语言基础入门:7个经典小程序助你快速掌握编程技巧
    本文精选了7个经典的C语言小程序,旨在帮助初学者快速掌握编程基础。通过这些程序的实践,你将更深入地理解C语言的核心概念和语法结构。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 哈密顿回路问题旨在寻找一个简单回路,该回路包含图中的每个顶点。本文将介绍如何判断给定的路径是否构成哈密顿回路。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
  • 问题描述:通过添加最少数量的括号,使得给定的括号序列变为合法,并输出最终的合法序列。数据范围:字符串长度不超过100。涉及算法:区间动态规划(Interval DP)。 ... [详细]
  • 本文详细介绍了C++中map容器的多种删除和交换操作,包括clear、erase、swap、extract和merge方法,并提供了完整的代码示例。 ... [详细]
  • 中科院学位论文排版指南
    随着毕业季的到来,许多即将毕业的学生开始撰写学位论文。本文介绍了使用LaTeX排版学位论文的方法,特别是针对中国科学院大学研究生学位论文撰写规范指导意见的最新要求。LaTeX以其精确的控制和美观的排版效果成为许多学者的首选。 ... [详细]
  • 丽江客栈选择问题
    本文介绍了一道经典的算法题,题目涉及在丽江河边的n家特色客栈中选择住宿方案。两位游客希望住在色调相同的两家客栈,并在晚上选择一家最低消费不超过p元的咖啡店小聚。我们将详细探讨如何计算满足条件的住宿方案总数。 ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 本文探讨了如何通过预处理器开关选择不同的类实现,并解决在特定情况下遇到的链接器错误。 ... [详细]
  • 本文介绍如何利用栈数据结构在C++中判断字符串中的括号是否匹配。通过顺序栈和链栈两种方式实现,并详细解释了算法的核心思想和具体实现步骤。 ... [详细]
  • 本文介绍如何从字符串中移除大写、小写、特殊、数字和非数字字符,并提供了多种编程语言的实现示例。 ... [详细]
  • 本文探讨了在使用Selenium进行自动化测试时,由于webdriver对象实例化位置不同而导致浏览器闪退的问题,并提供了详细的代码示例和解决方案。 ... [详细]
  • 题目描述:给定一个N*M的网格,初始时网格中有k个芯片,每个芯片的位置已知。玩家可以在每一步操作中将所有芯片沿同一方向移动一格。如果芯片到达边界,则保持不动。目标是通过一系列操作,使每个芯片依次访问指定的目标位置。 ... [详细]
author-avatar
情之秋梦痕
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有