P31-36 程序流程结构-循环结构

2024-03-12 08:58

本文主要是介绍P31-36 程序流程结构-循环结构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

while语句
作用:满足循环条件,执行循环语句。
语法:while(循环条件){循环语句}
解释:只要循环条件的结果为真,就执行循环语句。

示例:

#include <iostream>
using namespace std;int main() {//while 语句//依次输出0~9这9个数字int num = 0;while (num < 10) {cout << num << endl;num++;}//PS:提供跳出循环的出口,避免出现死循环return 0;
}

在这里插入图片描述
案例:
猜数字,系统随机生成一个1到100之间的数字。玩家进行猜测,如果猜错,提示玩家数字过大或过小,如果猜对恭喜玩家胜利,并且退出游戏。

#include <iostream>
using namespace std;
//time系统时间头文件包含
#include <ctime>int main() {//添加随机数种子 作用是利用当前系统时间生成随机数,防止每次随机数都一样srand((unsigned int)time(NULL));//1、系统生成随机数int num = rand() % 100 + 1;//生成0+1~99+1随机数//2、玩家进行猜测while (1){int val = 0;cin >> val;//3、判断玩家的猜测if (val > num){cout << "猜大了" << endl;}else if (val < num){cout << "猜小了" << endl;}else{cout << "猜对了" << endl; //猜对,退出循环break;// break,可以利用该关键字来退出当前循环}}return 0;
}

do…while 循环语句
作用:执行语句,再判断是否符合条件
语法:do{循环语句} while ();
与while的区别在于do…while会先执行一次循环语句,再判断循环条件。

示例:

#include <iostream>
using namespace std;int main() {//do...while语句//在屏幕中输出0到9这十个数字int num = 0;do{cout << num << endl;num++;} 	while (num < 10);system("pause");
}

在这里插入图片描述
案例:
水仙花数,是指一个3位数,它的每个位上的数字的3次幂之和等于它本身:
例如:1×1×1+5×5×5+3×3×3=153
利用do…while语句,求出所有3位数中的水仙花数。

#include <iostream>
using namespace std;int main() {//1、先打印所有数字int num = 100;do{//从所有三位数字中找到水仙花数int a = 0; //个位int b = 0; //十位int c = 0; //百位a = num % 10; //获取数字的个位b = num / 10 % 10; //获取数字的十位c = num / 100; //获取数字的百位if(a*a*a + b*b*b + c*c*c == num) //如果是水仙花数,才打印{cout << num << endl;}num++;} while (num < 1000);system("pause");
}

在这里插入图片描述
for 循环
作用:满足循环条件,执行循环语句
语法:for(起始表达式; 条件表达式; 末尾循环体){循环语句;}

示例:

#include <iostream>
using namespace std;int main() {//for循环//从数字0 打印到 数字9for(int i = 0; i < 10; i++){cout << i << endl;}return 0;
}

在这里插入图片描述展开来看:

#include <iostream>
using namespace std;int main() {//for循环//从数字0 打印到 数字9int i = 0;for(; ; ){if (i >= 10){break;}cout << i << endl;i++;}return 0;
}

循环顺序:
在这里插入图片描述
案例:敲桌子
从1开始数到数字100,如果数字个位含有7,或者数字是7的倍数,我们打印敲桌子,其余数字直接打印输出。

#include <iostream>
using namespace std;int main() {//敲桌子案例//1、先输出1~100数字for (int i = 1; i <= 100; i++){//2、从100个数字种找到特殊数字,打印敲桌子//如果是7的倍数、个位有7、或者十位有7,打印敲桌子if (i % 7 == 0 || i % 10 == 7 || i / 10 == 7){cout << "敲桌子" << endl;}else{cout << i << endl;}}return 0;
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

这篇关于P31-36 程序流程结构-循环结构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/800750

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

poj3750约瑟夫环,循环队列

Description 有N个小孩围成一圈,给他们从1开始依次编号,现指定从第W个开始报数,报到第S个时,该小孩出列,然后从下一个小孩开始报数,仍是报到S个出列,如此重复下去,直到所有的小孩都出列(总人数不足S个时将循环报数),求小孩出列的顺序。 Input 第一行输入小孩的人数N(N<=64) 接下来每行输入一个小孩的名字(人名不超过15个字符) 最后一行输入W,S (W < N),用

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

C语言程序设计(选择结构程序设计)

一、关系运算符和关系表达式 1.1关系运算符及其优先次序 ①<(小于) ②<=(小于或等于) ③>(大于) ④>=(大于或等于 ) ⑤==(等于) ⑥!=(不等于) 说明: 前4个优先级相同,后2个优先级相同,关系运算符的优先级低于算术运算符,关系运算符的优先级高于赋值运算符 1.2关系表达式 用关系运算符将两个表达式(可以是算术表达式或关系表达式,逻辑表达式,赋值表达式,字符

校验码:奇偶校验,CRC循环冗余校验,海明校验码

文章目录 奇偶校验码CRC循环冗余校验码海明校验码 奇偶校验码 码距:任何一种编码都由许多码字构成,任意两个码字之间最少变化的二进制位数就称为数据检验码的码距。 奇偶校验码的编码方法是:由若干位有效信息(如一个字节),再加上一个二进制位(校验位)组成校验码。 奇校验:整个校验码中1的个数为奇数 偶校验:整个校验码中1的个数为偶数 奇偶校验,可检测1位(奇数位)的错误,不可纠错。

Science|癌症中三级淋巴结构的免疫调节作用与治疗潜力|顶刊精析·24-09-08

小罗碎碎念 Science文献精析 今天精析的这一篇综述,于2022-01-07发表于Science,主要讨论了癌症中的三级淋巴结构(Tertiary Lymphoid Structures, TLS)及其在肿瘤免疫反应中的作用。 作者类型作者姓名单位名称(中文)通讯作者介绍第一作者Ton N. Schumacher荷兰癌症研究所通讯作者之一通讯作者Daniela S. Thomm

oracle11.2g递归查询(树形结构查询)

转自: 一 二 简单语法介绍 一、树型表结构:节点ID 上级ID 节点名称二、公式: select 节点ID,节点名称,levelfrom 表connect by prior 节点ID=上级节点IDstart with 上级节点ID=节点值 oracle官网解说 开发人员:SQL 递归: 在 Oracle Database 11g 第 2 版中查询层次结构数据的快速

Tomcat下载压缩包解压后应有如下文件结构

1、bin:存放启动和关闭Tomcat的命令的路径。 2、conf:存放Tomcat的配置,所有的Tomcat的配置都在该路径下设置。 3、lib:存放Tomcat服务器的核心类库(JAR文件),如果需要扩展Tomcat功能,也可将第三方类库复制到该路径下。 4、logs:这是一个空路径,该路径用于保存Tomcat每次运行后产生的日志。 5、temp:保存Web应用运行过程中生成的临时文件