第五讲 循环结构程序设计
C语言程序设计_05循环结构程序设计
5.2 DO…WHILE循环结构 5.2.1 DO…WHILE语句的格式 DO…WHILE语句的一般格式为: DO 语句 WHILE(表达式); DO…WHILE语句中的表达式表示循环的条件,可 以是任何表达式,常用的是关系表达式和逻辑表达 式。表达式必须加圆括号。语句是重复执行的部分, 称作循环体。
由亍循环体在表达式2乊后表达式3乊前执行所以把循环体语句放在表达式3的开头循环体语句不原来的i构成逗号表达式作为循环语句新的表达式3从而也就没有循环体语句了
第5章 循环结构程序设计
5.1 WHILE循环结构 5.2 DO…WHILE循环结构 5.3 FOR循环结构 5.4 与循环有关的控制语句 5.5 3种循环语句的比较 5.6 循环的嵌套 5.7 循环结构程序举例 本章小结
图5-6 FOR语句执行过 程
FOR语句的执行过程如图5-6所示。具体由以下几步 完成: (1)求表达式1。 (2)求表达式2,并判定其值为0或非0。若值为非0, 转步骤(3);否则结束FOR语句。 (3)执行语句,然后求表达式3。 (4)转向步骤(2)。 由FOR语句的执行流程可知,表达式1的作用是为循 环控制的有关变量赋初值,表达式2是循环控制条件, 表达式3用于修正有关变量,语句是重复执行部分。
【例5.7】输入20个数,求出其中的最大值与最小值。
5.3.3 FOR语句的各种变形 1.在FOR语句中省略表达式 FOR语句中的3个表达式可以部分或全部省略,下面 给出语句的4种基本变形。 (1)表达式1移至FOR语句前,但它后面的分号必 须保留。这时FOR语句的形式为: 表达式1; FOR(; 表达式2; 表达式3) 语句
(2)表达式3移至循环体语句之后,但它前面的分 号必须保留。FOR语句的形式为: FOR(表达式1; 表达式2;) { 语句; 表达式3; } 对于求P=5!的程序段,省略表达式3,将其放在循环 体中,则程序段写成:
第5章-循环结构程序设计PPT优秀课件
5.3.1 前测型Do…Loop循环语句
格式:
Do [While | Until <条件表达式>] <语句块> [Exit Do] <语句块>
Loop
18
5.3.1 前测型Do…Loop循环语句
前测型Do…Loop循环的流程图
Do While…Loop流程图
Do Until…Loop流程图
条件表达式 值为真?
格式:
Do <语句块> [Exit Do] <语句块>
Loop [While | Until <条件表达式>]
23
5.3.1 后测型Do…Loop循环语句
说明:
后测型Do…Loop循环语句与前测型Do…Loop循环语句的主 要区别在于:
后测型要先执行一次循环体,再判断条件;而前测型要 先判断条件,然后根据判断结果决定是否执行循环体。因此 对于后测型,不管条件是否满足,循环体至少有一次执行机 会。
16
5.3 Do…Loop循环语句
导入:
Do…Loop循环也属于条件型循环,即根据条件的 成立与否来决定是否执行循环。Do…Loop循环的应 用具有很强的灵活性,主要体现在:它既能指定循环 开始条件,又能指定循环结束条件;既能构成前测型 Do…Loop循环语句,又能构成后测型Do…Loop循 环语句。
25
5.3.1 后测型Do…Loop循环语句 【例5-10】将400~600间能够被3整除的数 输出(上机练习)
【例5-11】(略)
26
5.4 循环嵌套
介绍:
一个循环结构中又包含一个或多个循环结构被称为 循环嵌套,或称多重循环。 多重循环对嵌套的层数没有限制。有几层嵌套,就 称为几重循环,如二重循环、三重循环、四重循环 等。一般地,把嵌套在一个循环体内部的另一个循 环结构称为内循环;这样,嵌套了其他内循环部分 的循环结构就称为外循环。 为了使多重循环结构具有较好的可读性,通常用缩 进方式书写相应的源代码。
C语言程序设计:第5章 循环结构
12
do...while语句(cont...)
课堂练习: 1.输出1---n之间的数,其中n从键盘输入。
int main(void) {
//1.定义变量i和n //2.输入n的值 //3.思考循环的开始条件:i从1开始 //4.思考循环的结束条件:i++,i > n //5.循环的条件:i<=n //6.循环要做的事情:输出i的值 return 0; }
} 相当于 while(1) {
}
26
小结
❖for(i=m;i<n;i++)//循环次数:n-m次 ❖for(i=m;i<=n;i++)//循环次数:n-m+1次
27
循环语句的练习
课堂练习: 1.输出n---1之间的数,其中n>1且n从键盘输入。 2.计算1*2*3*...*n的值(n的阶乘n!), 其中n从键盘输入。 3.计算10- 1/2 - 1/3 -....1/n的值 以上练习分别以while、do...while、for语句实现
int main(void) {
//1.定义变量i,n,sum //2.输入n的值 //3.思考循环的开始条件:i从1开始 //4.思考循环的结束条件:i++,i > n //5.循环的条件:i<=n //6.循环要做的事情:累加i的值 //7.输出计算结果 return 0; }
24
for语句(cont...)
{
sum = sum + i;
if(sum > 100)break;
第五讲循环结构(for、while与repeat语句)
第四章第3节循环结构的程序设计For循环在实际应用中,会经常遇到许多有规律性的重复运算,这就需要掌握本章所介绍的循环结构程序设计。
在Pascal语言中,循环结构程序通常由三种的循环语句来实现。
它们分别为FOR循环、当循环和直到循环。
通常将一组重复执行的语句称为循环体,而控制重复执行或终止执行由重复终止条件决定。
因此,重复语句是由循环体及重复终止条件两部分组成。
一、计数循环(for/to/do)语句的一般格式for <控制变量>:=<表达式1> to <表达式2> do <语句>;for <控制变量>:=<表达式1> downto <表达式2> do <语句>;其中for、to、downto和do是Pascal保留字。
表达式1 与表达式2的值也称为初值和终值。
二、For语句执行过程①先将初值赋给左边的变量(称为循环控制变量);②判断循环控制变量的值是否已"超过"终值,如已超过,则跳到步骤⑥;③如果末超过终值,则执行do后面的那个语句(称为循环体);④循环变量递增(对to)或递减(对downt o)1;⑤返回步骤②;⑥循环结束,执行for 循环下面的一个语句。
三、说明①循环控制变量必须是顺序类型,初值和终值可以是常量、变量、表达式,且与控制变量类型一致。
例如,可以是整型、布尔型、字符型等,但不能为实型。
②循环控制变量的值递增或递减的规律是:选用to则为递增;选用downto则递减。
③所谓循环控制变量的值"超过"终值,对递增型循环,"超过"指大于,对递减型循环,"超过"指小于。
④循环体可以是一个基本语句,也可以是一个复合语句。
⑤循环控制变量的初值和终值一经确定,循环次数就确定了。
但是在循环体内对循环变量的值进行修改,常常会使得循环提前结束或进入死环。
第五讲 循环结构程序设计
四、练习 例1:计算1+2+3+4+…+100之和。
问题分析:对于求和,我们使用的是累加的方法:设置循环初值为 1,终值为100的重复100次的循环,每次将循环控制变量I迭加加入一 个变量s中,循环结束此变量中的值即为所求数值和,如下所示:
program p1; var i,s:integer; begin s:=0;
当型循环(while/do语句) 当型循环语句(while语句)是这样描述循环的:当 指定条件成立时重复执行指定语句。 一、格式 格式: While 布尔表达式 do 语句;
二、执行过程 while语句执行的过程是:先求布尔表达式的值,当其为 真时,重复执行指定语句,当其值为假时,终止循环。
三、注意事项
program p3;
var i,m,n,k:integer; begin for i:=1000 to 9999 do begin
k:=(m+n)*(m+n); if k:=i then writeln(i); end; end.
m:=i div 100;
n:=i mod 100;
例4:编程找出四位整数abcd中满足下述关系的数:
循环结构是指当某个条件满足时反复执行某些语句, 否则就不执行。在循环语句中必须说明:重复循环对象是 一条或多条语句,称为循环体;重复循环的控制条件用来 控制循环执行。
计数循环(for/to/do语句)
我们有时候希望重复执行一组语句,重复的 次数已知,而不依赖于循环中语句的结果,在 Pascal语言中这样的结构用for语句来描述。 一、格式
第五讲
循环结构程序设计
在程序处理中,经常需要对某一条或一组语句重复执 行多次,以最终完成某项任务,这就是循环的概念。例如: 统计所有考生的成绩总分需要一个人一个人地计算;寻找 一批数据中的某一个,需要逐个地鉴别等。这类处理的一 个特点是对不同的运算对象进行重复若干次的相同运算处 理,这种处理模式在程序设计语言中使用循环结构来实现 的。循环结构是程序设计的三种基本结构之一。
C语言程序设计第5章-循环结构程序设计ppt课件
while(i<=k && !flag)
if(n % i==0) flag=1;
else i=i+1;
if(!flag)
printf("%d is a prime
number.\n",n);
else
printf("%d is not a prime
number.\n",n);
}
.
返回本章首页
第5章 循环结构程序设计
【例5_1】用while语句求p=n!
#include<stdio.h>
int main()
{ int i=1,p=1; //循环初始化部分 while(i<=5) //循环控制部分
{ p=p*i; //循环体语句 i++; //循环修改部分
}
printf("5!=%d\n",p);
return 0;
10-3,则再执行循环体,把 term 值赋给term1.然后再累加 到s中去。可以看出:程序中 term1代表当前要累加的项, term代表下一项,如果这两项 之差未超过10-3,就将下一项 加到s 中。
第五节 循环结构程序设计
运行结果为
pi=3.141592
注意:不要把n定义为整型变量,否则在执行“t=s/n;”时,得到t的值为0(原因是两个整数相除)。
例5.4求Fibonacci数列前40个数。这个数列有如下特点:第1、2个数为1、1。从第3个数开始,每个数是其前面两个数之和。即
F1=1 (n=1)
F2=1 (n=2)
#include <iomanip>
using namespace std;
int main( )
{int m,k,i,n=0;
bool prime;//定义布尔变量prime
for(m=101;m<=200;m=m+2) //判别m是否为素数,m由101变化到200,增量为2
{prime=true;//循环开始时设prime为真,即先认为m为素数
{int s=1;
double n=1,t=1,pi=0;
while((fabs(t))>1e-7)
{pi=pi+t;
n=n+2;
s=-s;
t=s/n;
}
pi=pi*4;
cout<<"pi="<<setiosflags(ios∷fixed)<<setprecision(6)<<pi<<endl;
return 0;
while语句的一般形式如下:
while (表达式)语句
其作用是:当指定的条件为真(表达式为非0)时,执行while语句中的内嵌语句。其流程图见图5.1。其特点是:先判断表达式,后执行语句。while循环称为当型循环。
图5.1
例5.1求1+2+3+…+100。
c语言第5章循环结构程序设计课件
第五章 循环结构程序设计
典型例题(例5-8) :求两个整数的最大公约数、最小公倍数
12 8 4 mn r
84
0
mn r
最大公约数 4 最小公倍数 12*8/4=24
求最大公约数的N-S流程图
辗转相除法
7
第五章 循环结构程序设计
void main( )
{ int n, m, nm, r, t; printf( " Enter m, n= ? " ) ; scanf( " % d% d" , & m, & n) ; nm= n* m; if ( m< n)
例如: for(i=1;i<=n;) { t=t*i; i++; } (4)可以省略表达式1和表达式3,只有表达式2 , 即只给循环条件。
i=1; for(;i<=n;)
{t=t*i; i++;}
14
第五章 循环结构程序设计
(5) 3个表达式都可省略。 例如: for(;;) 语句 相当于 while(1)语句。
3
第五章 循环结构程序设计
例: 编程序求: s=1+2+3+……+100
main()
{ int s=0,i=1;
while (i<=100) { s=s+i;
思考:如何求n!
i++; }
printf("S=%d",s); }
4
第五章 循环结构程序设计 二、 do...while语句
Do-while语句的一般形式为:
(1) while( ) {… while( ) {…}
C语言程序设计课件第5章 循环结构程序设计
完整版ppt
19
➢break语句的一般形式为: break;
只能用于循环语句和switch 语句之中,而不能单独使用
完整版ppt
20
5.5.2 用continue语句提前结束 本次循环 P126
➢ continue语句的一般形式为:
continue;
➢其作用为结束本次循环,即跳过循环体 中下面尚未执行的语句,接着进行下一 次是否执行循环的判断。
循环体
完整版ppt
7
while语句的一般形式如下:
while (表达式) 语句
循环条件表达式
“真”时执行循环体语句 “假”时不执行
表达式
0(假)
while循环的特点是: 先判断条件表达式 后执行循环体语句
非0(真) 语句
完整版ppt
8
P117
5.2.2 用do…while语句实现循环
➢do---while语句的特点:先无条件地执
第5章 循环结构程序设计 P115
5.1 程序中需要用循环结构
5.2 用while语句和do…while语句实现循环 5.3 用for语句实现循环
5.4 循环的嵌套
5.5 提前结束循环
5.6 几种循环的比较
5.7 程序举例
5.8 提高部分
完整版ppt
1
5.1 程序中需要用循环结构 P115
➢现实生活中许多问题是需要重复处理
➢for语句的一般形式为 for(表达式1;表达式2;表达式3) 语句
作为循环的调整器,例如 使循环变量增值,它是在 执行完循环体后才进行的
完整版ppt
14
➢for语句的执行过程:
(1) 先求解表达式1 (2) 求解表达式2,若其值为真,执行循环体, 然后执行下面第(3)步。若为假,则结束循环, 转到第(5)步 (3) 求解表达式3 (4) 转回上面步骤(2)继续执行 (5) 循环结束,执行for语句下面的一个语句
c语言课件-第五章-循环结构程序设计
5.5 for语句(当型循环)
例:读程序,判断程序的功能 #include<stdio.h> void main( ) {char c; for(;(c=getchar( ))!=‘\n’;) putchar(c); } 输入ok!<回车>,输出_______
读入一个字符,当它不是回车符就输出.
5.5 for语句(当型循环)
分析:用辗转相除法求最大公约数。
5.3 while语句(当型循环)
5.3 while语句(当型循环)
例:利用while语句计算1+1/2+1/4+1/6…+1/50.
解:观察数列1,1/2,1/4,1/6…,1/50。
分子全部为1,分母除第一项外,全部是偶数。 同样考虑用循环实现。
其中累加器用sum表示(初值设置为第一项1,以 后不累加第一项),循环控制用变量i(i:2-50)控 制,数列通项:1/i。
5.2 goto语句及用goto构成循环
一、goto语句 goto语句的一般形式:goto 语句标号
语句标号:用于定义程序中的某个位置 用标识符表示,不能只用数字
如:goto start(对) goto 20(错)
goto语句的功能是无条件地转到标号所指的语句。
因为滥用goto语句会破坏结构化,所以应该限制 使用goto语句。
i=1 for(; i<=3; )
{ s=s+k; i++; }
i=1 while (i<=3)
{ s=s+k; i++; }
5.5 for语句(当型循环)
(6)表达式2一般是关系表达式或逻辑表达式,但 也可以是数值表达式或字符表达式,只要其值不等于 0就执行循环体。
C语言程序设计第5章循环结构程序设计简明教程PPT课件
循环结构程序设计
第5 章
循环结构程序设计
当你对C语言程序设计有了一定了解和掌握后,若 想要处理一些更复杂的任务时,当满足某一条件想反 复执行某个程序时,该如何处理呢?
控制语句能够控制程序的流程,根据判断决 定重复运行什么。
程序的三种结构
•顺序结构 •选择结构 •循环结构
本章所
学Байду номын сангаас目标
了解循环结构的特点; 掌握while语句、do-while语句、for语句; 掌握while循环结构、do-while循环结构、for循 环结构 掌握break和continue语句的使用; 理解循环嵌套。 掌握各种循环的应用;
C语言程序设计
第5章 循环结构程序设计
4
【例5.1】输入10个数,求它们的和并输出。
#include <stdio.h> int main() { float x,sum=0; int k=0; while(k<10) { printf("please input x:\n"); scanf("%f",&x); //输入一个数 sum=sum+x; //进行累加 k++; } printf("sum=%f\n",sum); return 0; } 运行结果: please input x:5↙ please input x:7↙ please input x:8↙ please input x:14↙ please input x:53↙ please input x:12↙ please input x:35↙ please input x:9↙ please input x:10↙ please input x:47↙ sum=200
北京航空航天大学《C语言程序设计》课件-第五章循环结构程序设计
2023/4/2
5.3 do-while语句
15
语句一般格式
do
{语句组} while (表达式);
功能:
– 先执行内嵌语句(循环体),之后计算 表达式的值,不为0(逻辑真)时,再 执行循环体并判断条件,直到表达式的 值为 0 结束循环,转去执行while下面 的语句。
2023/4/2
do-while循环的算法
for(n=100;n<=200;n++) {
if (n%7!=0) continue;
printf("%6d",n); j++; if (j%10==0)
printf("\n"); } printf(" \n j=%d\n",j); }
29
2023/4/2
5.5.2 循环中break的应用
30
功能:
}
无循环体
} 循环体
2023/4/2
5.5 循环结构中的跳转语句
25
有如下三种语句实现跳转: – continue语句 – break语句 – goto语句
功能:在循环语句的循环体中使用,可 以进行循环的流程控制
2023/4/2
5.5.1 continue语句及应用
26
功能:
– 中断循环体的本次执行(即跳过循环体中尚未 执行的语句),立即开始执行下一次循环。
– 利用break语句能够强迫终止本层循环, 转到后续语句执行。
while语句
表达式? N
Y
… break;
…
do-while语句
… break;
…
表达式? N
Y
第五讲 循环结构程序设计
普通高等教育“ 普通高等教育“十一五 ” 国家级规划教材
程序运行结果: 程序运行结果: pi=3.141397
/* 当满足条件时结束 */ /* 计算通项并进行累加 */ /* i值加 得到下一个奇数 */ 值加2得到下一个奇数 值加 /* 相邻项符号取反 */ /* 求公式中的某一项 求公式中的某一项temp */
循环的概念
普通高等教育“ 普通高等教育“十一五 ” 国家级规划教材
种循环语句来实现: C语言提供了3种循环语句来实现: 语言提供了 种循环语句来实现 (1) while( )~循环语句 ~ (2) do~while ( )循环语句; ~ 循环语句; 循环语句 (3) for( )~循环语句。 ~循环语句。 下面我们将分别介绍这三种循环语句。 下面我们将分别介绍这三种循环语句。
图4-2 计算1~100累计和的流程图和 计算 ~ 累计和的流程图和N-S图描述 图描述 累计和的流程图和
4.3.2 while 语句
#include <stdio.h> void main() { int i,sum; sum=0; i=1; while(i<=100) { sum=sum+i; i=i+1; } printf("sum=%d\n",sum); } 程序运行结果: 程序运行结果: sum=5050
4.3.4 for循环 循环
普通高等教育“ 普通高等教育“十一五 ” 国家级规划教材
for循环语句的作用: 首先求解表达式 的值,然后求解表 循环语句的作用: 首先求解表达式1的值 的值, 循环语句的作用 达式2的值 若表达式的值非0( 的值, 就执行循环体, 达式 的值,若表达式的值非 (真)时,就执行循环体,执行 一次循环体后求解表达式3的值 再求解表达式2的值 的值,再求解表达式 的值, 一次循环体后求解表达式 的值 再求解表达式 的值,若表达式 2仍不为 再执行循环体 再求解表达式 的值 。如此反复直到表 仍不为0再执行循环体 再求解表达式3的值 仍不为 再执行循环体,再求解表达式 的值。 达式2的值为 的值为0时 整个循环结束 其执行过程如图所示。 整个循环结束。 达式 的值为 时,整个循环结束。其执行过程如图所示。
第05讲 循环结构程序设计.ppt
第 五
算它们的和与平均值。
章
输入文件样例
输出文件样例
循 环
12 15
结 456
构 78
程 12345
序 5698
设 计
7894
0
2
26503 2650.30
num.pas num.in num.out
3
第 五
【练习4】已知文件ch.in中有连续存
章 放的100个字符,编程将这100个字符
复制到文件ch.out中去。
writeln(sqrt(i):0:3);
设 End.
计
第
五 章
第五讲
循
环 结
循环结构程序设计
构
程
序
设 计
第 五 章
循 第一节 for循环程序设计
环
结
构 程
——用于已知次数的循环
序
设
计
计算机在执行一个程序模块时,不是按照
第 语句的排列顺序进行的,而是按照一定的规律
五 章
和规则在一定的条件下重复执行模块内部的一 系列语句,那么我们可以把这种结构看作是循
【例2】统计一个包含各种可见字符的
第 五
文本文件中数字字符的个数。
章 n:integer; ch:char; f:text;
循 n:= 0 ;
环 结
while not eof(f)
do
构 程
begin
序 设
read(f,ch);
计 if (ch>='0') and (ch<='9') then inc(n);
环结构。这种结构的程序设计可以称为循环程
循 序设计。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第五讲循环结构程序设计
问题引出:自然数求和
while语句(条件循环)
语句格式
while(表达式)
<语句>
流程:如右图。
【思考】
1、流程如何出while循环?
2、while循环在什么情况下可能陷入死循环?
3、流程流过while循环时,必执行循环体中的语句吗?
4、如下程序段后,i的值是?
int i=5;
while(i) i--;
printf("%d",i);
5、如下程序段后,i的值是?
int i=0;
while(i++<100);
printf("%d",i);
【练习】
1、解决上面的自然数求和问题。
2、输入一个自然数N,求N!=1×2×3×……×N
3、输入一个八位以内正整数,判断该数是几位数,并以逆序的形式输出。
Enter an number: 1234567
Backwards number: 7654321
digits: 7
do…while语句
语句格式
do
<语句>
while (表达式);
流程:如右图。
说明:
1、先执行循环体一次再进行判断。
(与while循环的区别)
2、最后一句while(表达式)后应加分号!
【练习】用do-while解决以上问题。
for语句
语句格式
for(表达式1;表达式2;表达式3)
<语句>
衍生形式
for(表达式1;表达式2; ) <语句>
for( ;表达式2;表达式3) <语句>
for( ;表达式2;) <语句>
for( ;;) <语句>
例:阅读程序,分析结果
#include <stdio.h>
void main(){
char c;
for(;(c=getchar())!='\n';)
putchar(c);
getch();
}
扩展:统计字符个数。
【练习】
1、试用各种for形式解决自然数求和问题。
循环结构程序设计示例
1.求1+2!+3!+ (10)
2.输入五个整数,输出其中的最大数和最小数。
3.输入两个自然数m和n,求它们的最小公倍数。
边学边练
1.试用while语句和for语句改写下列程序,保持意义不变。
#include <stdio.h>
void main(){
int s=0,a=1,n;
scanf("%d",&n);
do{
s+=1;
a=a-2;
}while(a!=n);
printf("%d\n",s);
getch();
}
若要使程序的输出值为2,则应该从键盘给n输入的值是。
2.输出所有字母的ASCII码,结果如下所示:
3.输入两个自然数m和n,求它们的最大公约数。
(绘制流程图)
4.设计一个累加器程序,输入一组数(以999为结束标志),求它们的总
和与平均值。