第4讲 循环结构while1

合集下载

第四章。循环结构(while、do-while、for)

第四章。循环结构(while、do-while、for)

第四章。

循环结构(while、do-while、for)Top1.循环结构(while、do…while、for)1. 循环结构(while、do…while、for)1.1. 什么是循环结构在日常生活中,会有很多需要反复执行的事情,比如:每一年的4个季节,每一周的7天,每日的3餐,打印机每份文档打印50份,一圈跑道400米跑3圈,都是在反复执行的。

再看软件系统中的需求:问题1:输出100行语句,每行语句都一样,即:行动是成功的阶梯,行动越多,登得越高!行动是成功的阶梯,行动越多,登得越高!行动是成功的阶梯,行动越多,登得越高!…问题2:输出100行语句,每行语句都类似,即:第1,行动是成功的阶梯,行动越多,登得越高!第2,行动是成功的阶梯,行动越多,登得越高!第3,行动是成功的阶梯,行动越多,登得越高!…第100,行动是成功的阶梯,行动越多,登得越高!问题3:计算1到50乘以8.88的结果1×8.88 =8.882 ×8.88 =17.763 ×8.88 =26.644 ×8.88 =35.52…50 ×8.88 =444诸如此类问题都是在反复执行的,在软件系统中可以通过循环这种语法结构来解决。

循环是程序设计语言中反复执行某些代码的一种计算机处理过程,是一组相同或相似语句被有规律的重复性执行。

对于循环来说,需要考虑两个要素,其一要素为循环体,也就是被反复执行的相同或相似的语句,其二要素为循环的条件,也就是循环得以继续执行下去的条件,常常以循环次数的方式体现。

常用的循环结构有:while、do-while、for。

1.2. while语句1.2.1. while语句的执行逻辑while语句是循环的一种常见语法结构,语法如下:1.while(boolean表达式){语句块;2.}while语句的执行过程为,首先计算boolean表达式的值,而后进行判断,若值为true则执行语句块,语句块执行完后再次判断boolean表达式的值,如果为true则继续执行语句块,如此循环往复,直到boolean表达式的值为false时退出while循环而执行while之后的语句。

循环结构-while语句

循环结构-while语句
循环结构——while语句
BRAND PLANING
Pascal暑假微课系列
知不知道循环次数?
CONTENTS
01 pascal循环
02 while语句
04 已经知道循环次数
05 ——for语句
03 不知Байду номын сангаас循环次数 06 repeat语句
(当型循环)while语句
添加标题
while 布尔 表达式 do 循环体语句
var x,sum:integer; while x<=101 do x:=x+5; end.
begin begin end;
一级算法:
1. 初始化sum为0,x为1; ① while x<=101 do
2. begin ① 把x累加到sum中 ② x增加5
3. end ① 输出sum
○ 分析:设x累加的数,x最小为1,最大为101,和是sum,它们都是整数类型。
一.初始化sum为0,x为1;
二.while x<=101 do ○ begin
添加标题
格式:
添加标题
注意:
添加标题
(当型循环)while语句
添加标题
添加标题
为使while循环正常终止,布 尔表达式中所含变量的值, 在循环体中一定要有所更改;
while循环中,do后面的语句 可以是一个简单语句,也可 以是用begin—end形成的复
合语句。
例:编程计算1+6+11+……+101=
三.把x累加到sum中 ○ sum:=sum+x
二级求精:
四.x增加5 ○ x:=x+5 ○ end

C语言讲课-while循环结构课件

C语言讲课-while循环结构课件
输入:1
输入:101=0
输出:
sum=101
此程序的功能?
什么情况下两者结果相同?
二、do-while语句
5.3 for语句
语句一般格式 for (表达式1;表达式2;表达式3) 语句
功能:计算表达式1的值,再判断表达式2,如果其值为非0(逻辑真),则执行内嵌语句(循环体),并计算表达式3;之后再去判断表达式2,一直到其值为0时结束循环,执行后续语句。
?
-3
do-while语句
语句一般格式 do 语句 while (表达式); 功能:先执行内嵌语句(循环体),之后计算表达式的值,不为0(逻辑真)时,再执行循环体并判断条件,直到表达式的值为 0 结束循环,转去执行while下面的语句。
do-while循环的算法

2
)直到型循环(
while循环控制结构
假设一张报纸厚0.1毫米,将报纸从中间对折多少次后,报纸高度会超过珠穆朗玛峰?
#include <stdio.h>void main( ){ float t=0.0001; int n=0; while(t<=8844) { t=t*2; n++; } printf(“ %d\n”,n);}
while循环控制结构
假设一张报纸厚0.1毫米,将报纸从中间对折,报纸会有多厚?
#include <stdio.h>void main( ){ float t=0.0001; t=t*2; printf(“ %f”,t);}
while循环控制结构
假设一张报纸厚0.1毫米,将报纸从中间对折,报纸会有多厚?
学习内容
循环结构的引入
C语言提供了三种循环控制语句,构成了三种基本的循环结构:while语句构成的循环结构do-while语句构成的循环结构for语句构成的循环结构

c语言中while的用法

c语言中while的用法

c语言中while的用法c语言中的while循环是一种常见的迭代控制流程,它允许我们根据特定条件重复执行一段代码块。

while循环的基本形式是在关键字while后跟一个括号 ( ),其中包含一个条件表达式。

当条件表达式为真时,while循环的代码块会被执行;当条件表达式为假时,代码块将被跳过,程序继续向下执行。

下面我将逐步解释while循环的用法以及一些常见的相关概念。

1. while循环的语法结构在C语言中,while循环的语法结构如下:while (condition) {循环体代码}这里的condition是一个任意的表达式,它用来决定循环是否继续执行。

当condition为真时,循环会继续执行,否则循环将结束。

2. while循环的执行过程当程序执行到while循环时,首先会计算condition的值。

如果condition 为真,则执行循环体中的代码;否则,跳过循环体,继续执行后面的代码。

在循环体中,我们可以编写任意的代码,包括语句和其他的控制流结构(如if语句、switch语句等),以满足特定的需求。

3. while循环的条件表达式while循环的条件表达式通常由一个或多个关系运算符(如等于、大于、小于等)和逻辑运算符(如与、或、非)组成。

条件表达式的结果必须是一个布尔值(true或false)。

通常情况下,我们会使用变量或者算术表达式作为条件表达式的一部分。

确保在循环中更新这些变量的值,以免陷入无限循环。

4. while循环的使用场景while循环常用于需要重复执行某些操作,直到满足某个条件为止的情况。

比如:处理用户输入:我们可以使用while循环来持续读取用户的输入,并在满足某个条件时终止循环,如输入特定字符。

遍历数据结构:对于数组或链表等数据结构,我们可以使用while循环来遍历其中的元素,并执行相关的操作。

处理文件内容:我们可以使用while循环读取文件的内容,直到达到文件结尾或满足特定条件为止。

循环结构专业知识讲座

循环结构专业知识讲座
0.0195313
第二节 while语句 (四)上机练习:
2.角谷猜测【1.5编程基础之循环控制18】 谓角谷猜测,是指对于任意一种正整数,假如是奇数,则乘3加1,
假如是偶数,则除以2,得到旳成果再按照上述规则反复处理,最终 总能够得到1。如,假定初始整数为5,计算过程分别为16、8、4、2、 1。程序要求输入一种整数,将经过处理得到1旳过程输出来。 输入: 一种正整数N(N <= 2,000,000) 输出: 从输入整数到1旳环节,每一步为一行,每一部中描述计算
#include <iostream> using namespace std; int main () {
int sum=0; for (int i=1; i<=100 ; ++i)
sum+=i; cout << sum; return 0; }
第一节 for语句 (四)例题分析:
例4.3 利用for循环计算n!旳值。分析:n!=1*2*3…*n
第一节 for语句 (四)例题分析:
#include <iostream> using namespace std; int main ( ) {
char c,ci; printf(“输入一种字母\n”); c=getchar( ); for(ci=‘A’,ci<=c,ci++) printf(“%c”,ci); ci--; for( ,ci>=‘A’,ci--) printf(“%c”,ci); printf(“\n”); }
第二节 while语句 (二)格式举例:
(1) i=0; while (i<10) ++i;

第4章 循环结构(C++版)_第二节 while语句-2019-01-04

第4章  循环结构(C++版)_第二节  while语句-2019-01-04

【上机练习】
2.角谷猜想【1.5编程基础之循环控制18】 /ch0105/21/ :8088/problem_show.php?pid=1086 谓角谷猜想,是指对于任意一个正整数,如果是奇数,则乘3加1,如果是偶数,则除以 2,得到的结果再按照上述规则重复处理,最终总能够得到1。如,假定初始整数为5,计算 过程分别为16、8、4、2、1。程序要求输入一个整数,将经过处理得到1的过程输出来。 输入: 一个正整数N(N <= 2,000,000) 输出: 从输入整数到1的步骤,每一步为一行,每一部中描述计算过程。最后一行输出"End"。 如果输入为1,直接输出"End"。 样例输入: 5 样例输出: 5*3+1=16 16/2=8 8/2=4 4/2=2 2/2=1 End
第二节 while语句
第2种方法也许更加常用(你再 最后,我们来更仔细地研究一下 也不用记住%d、%lf等恼人的占位符 输入输出。研究对象就是经典的“A+B” 问题:输入若干对整数,输出每对之和。 了): 假设每个整数不超过109,一共不超过 #include<iostream> 106个数对。 using namespace std; 第1种方法是: #include <cstdio> int main() { int a,b; while(scanf("%d%d",&a,&b)==2) printf("%d\n",a+b); return 0; } int main() { int a,b; while(cin >> a >> b ) cout << a+b <<endl; return 0; }

while循环知识点

while循环知识点

while循环知识点while循环是编程语言中常用的一种循环结构,用于反复执行一段程序代码,直到指定条件不再成立为止。

本文将介绍while循环的知识点和常见应用场景。

1. while循环的语法结构while循环的语法结构如下所示:while (条件表达式) {循环体语句;}条件表达式是一个布尔表达式,它的值为真时循环体语句就会被执行,否则就会跳过循环体语句直接退出循环。

while循环的执行过程是先判断条件表达式的值是否为真,如果为真就执行循环体语句,然后再回到顶部重新判断条件表达式的值,直到条件表达式的值为假为止。

2. while循环的应用场景while循环可以用于很多场合,比如需要反复读取用户输入直到输入正确为止,或者需要反复处理数据直到满足某个条件为止。

下面列举几个常见的应用场景:(1)计算累加和在循环体语句中累加变量的值,直到达到指定的上限。

例如,计算1到100之间所有整数的和:int sum = 0;int i = 1;while (i <= 100) {sum += i;i++;}printf('1到100之间所有整数的和为:%d', sum);(2)查找数组中的最大值遍历数组中的元素,找到其中的最大值。

例如,查找一个整型数组中的最大值:int a[] = {5, 2, 9, 4, 7};int n = sizeof(a) / sizeof(a[0]);int max = a[0];int i = 1;while (i < n) {if (a[i] > max) {max = a[i];}i++;}printf('数组a中的最大值为:%d', max);(3)输入验证反复提示用户输入,直到用户输入一个符合要求的值。

例如,要求用户输入一个大于0的整数:int n;while (1) {printf('请输入一个大于0的整数:');scanf('%d', &n);if (n > 0) {break;}printf('输入有误,请重新输入!');}printf('你输入的整数为:%d', n);3. while循环的注意事项在使用while循环时,需要注意以下几点:(1)循环体语句中必须修改条件表达式的值,否则循环将会变成一个死循环,导致程序无法正常退出。

while循环知识点总结

while循环知识点总结

while循环知识点总结一、while循环的语法结构在大多数编程语言中,while循环的语法结构如下所示:```plaintextwhile (条件) {// 循环体}```其中,条件是一个布尔表达式,如果条件为真,就会执行循环体中的代码;如果条件为假,循环将终止,程序将继续执行循环体之后的代码。

在循环体内部,我们可以编写任意需要重复执行的代码,比如增加或减少变量的值,打印输出信息等。

二、while循环的工作原理当程序执行到while循环时,首先会判断条件是否为真。

如果条件为真,就会执行循环体中的代码;然后再次判断条件是否为真,如此往复,直到条件不再满足为止。

当条件不再满足时,程序会跳出循环,继续执行循环体之后的代码。

如果条件一开始就不满足,循环体中的代码将不会被执行,直接跳过循环,执行循环体之后的代码。

三、while循环的常见用法1. 遍历数组或列表while循环可以用于遍历数组或列表中的元素,常见的做法是使用一个变量作为索引,来依次访问数组或列表中的每个元素。

```plaintextint i = 0;while (i < arr.length) {// 访问arr[i]i++;}```2. 无限循环有时候我们需要一个无限循环,可以使用while(true)来实现。

```plaintextwhile (true) {// 无限循环}```在这种情况下,需要小心处理循环终止的条件,以免陷入死循环。

3. 条件循环while循环也可以根据特定的条件来执行或终止。

```plaintextint count = 0;while (count < 10) {// 循环体count++;}```在这个例子中,循环会执行10次,每次执行后count会增加1,直到count的值不再小于10为止。

4. 循环中的控制语句在while循环中,我们经常会使用break语句和continue语句来跳出循环或者继续下一轮循环。

循环结构(while)(课件)-高中信息技术教材配套教学课件(浙教版2019必修1)

循环结构(while)(课件)-高中信息技术教材配套教学课件(浙教版2019必修1)

Python程序设计语言
break
Python程序设计语言
while else
若限制猜测次数,每轮最多猜测三次,若次数用完 则输出“次数已用完”,程序该如何修改
while 表达式 : • 如果循环正常执行完(没有执行break
循环体
语句跳出循环),则执行else语句块
else: 语句块
• 若经过break语句跳出循环,则else的 语句块不执行
N 语句块2
Python程序设计语言
循环结构
对某个条件进行判断,当符合条件时, 执行Y指向的循环体 然后返回重新判断这个条件,当符合条 件时,再次执行循环体 重复上述过程,直到不符合条件,则循 环结束,执行循环体后面的指令。
条件表 达式? Y
循环体
N 语句块
Python程பைடு நூலகம்设计语言
whlie
while 条件表达式: 循环体
程序运行后,输人n的值为88, 最终n的值是( B )
A.44 B.11 C.22 D.88
课堂练习
★某Python程序下:
s=[3,8,34,45,23,46,90,44,7,13,6,2] num=0 i=0 while i<len(s):
if s[i]<10: num=num+s[i]
i=i+1 print(num)
循环条件是什么?
“偏大”(guess>number),继续猜数。
Python程序设计语言
猜数字
Python程序设计语言
猜数字
Python程序设计语言
猜数字
引入布尔型变量, 直接控制循环条件
若不引入布尔型变量,程序是否有其他写法

高中信息技术必修课件while循环语句

高中信息技术必修课件while循环语句
首先执行外层while循环的条件判断,若条件满足则进入外层循环体。
02
执行内层循环
在外层循环体内,遇到内层while循环语句,执行内层循环的条件判断
,若条件满足则进入内层循环体。
03
内外循环交互
内层循环执行完毕后,返回到外层循环的下一个语句继续执行,直到外
层循环结束。若内层循环中有break或continue语句,会影响内外循环
案例三:猜数字游戏实现过程
01
代码实现
02
```python
import random
03
案例三:猜数字游戏实现过程
answer = random.randint(1, 100)
guess = int(input("请猜一个1到100之间的整数:"))
案例三:猜数字游戏实现过程
1
num_guesses = 0
变量在while循环中作用
控制循环次数
通过改变计数器变量的值,可以 控制while循环的执行次数。
存储中间结果
在循环过程中,变量可用于存储 计算过程中的中间结果。
作为条件判断依据
变量可以作为while循环条件判 断的依据,决定循环是否继续执
行。
数据类型与变量关系
数据类型决定了变量的存储方 式和取值范围,不同的数据类 型对应不同的变量类型。
在while循环中,需要根据实际 需求选择合适的数据类型和相 应的变量。
变量的正确使用和数据类型的 合理选择是编写高效、稳定程 序的基础。
05 while循环常见错 误与调试方法
常见错误类型及原因
无限循环
由于条件表达式设置不当,导致循环无法终止,程序陷入死循环 。
缺少更新语句

全国计算机等级考试笔试讲义(第4章 循环结构)PPT课件

全国计算机等级考试笔试讲义(第4章 循环结构)PPT课件
内外层循环变量不能相同 分别用 i 和 j
考点5 break语句和continue语句
1、break语句
功能:在循环语句和switch语句中,终止并跳出循环 体或开关体
说明: break只能终止并跳出最近一层的结构 break不能用于循环语句和switch语句之外的任 何其它语句之中
while
4.5 实例解析
【例】显示输入的字符, 如果按的是Esc键, 则退出循环; 如果按 的是Enter键, 则不做任何处理,继续输入下一个字符。
#include “conio.h” main( ) { char ch;
for (; ;) { ch=getchΒιβλιοθήκη ); /*不带回显的字符输入函数 */
if (ch==27) /* Esc键的ACSII码为27*/ break; /*退出循环*/
假(0) expr
真(非0) …… break; ……
do
……
break;
…...
真(非0)
while
expr
假(0)
for
expr1
假(0) expr2
真(非0) …… break; …...
switch
expr
const 1
case const 2
const n default
语句组1 break;
for ❖仅用于循环语句中
expr1 假(0)
expr2 真(非0)
…… continue;
…...
expr3
do
……
continue;
…...
真(非0)
while
expr
假(0)
while
假(0) expr

高中信息技术粤教版(2019)必修1 课件 4-4-1 while循环语句

高中信息技术粤教版(2019)必修1 课件 4-4-1 while循环语句
while循环语句形式
一、while循环:
while循环语句的一般形式:
while(表达式):
语句或语句组
说明:while循环是当型循环,只要条件满足,就 不断循环;否则,退出循环。
(1)表达式一般是一个关系表达式或一个逻辑表 达式,表达式的值应该是一个逻辑值真(True) 或假(False)。
(2)当表达式的值为真时,执行循环体语句;当 表达式的值为假时,退出循环,执行循环体外的 下一条语句(即while后面没有缩进的语句)
实例研究源程序
程序语句: n=0 s=0 while(s<10000):
n=n+1 s=s+n print(n)
while循环语句
二、练习 1、当t<=10执行“i=i+1: t=t×i”直至条件不成立。
2、重复执行“i=i+1 : t=t×i”直到条件t>10成立。
实例研究源程序
用while编写程序如下:用for编写程序如下:
s=0;i=0
s=0
while(i<100):
for i in range(1,101):
i=i+1;s=s+i
s=s+i
print(s)
print(s)
实例研究
例3:求满足1+2+…+n>10000的最小的 自然数n。
分析:可以通过累加实现求解。累加变 量为t,累加数用n表示。n从0开始,每 次加1并累加到t中,直至t的值超过 10000。
一、while循环: while循环语句的一般形式:
while(表达式): 语句或语句组
(3)每次循环都是执行完循环体语句后回到表达 式处重新开始判断,重新计算表达式的值。一旦 表达式的值为假就退出循环,为真时就继续执行 循环体语句。

c语言while循环(1)PPT课件

c语言while循环(1)PPT课件

N
i<=100
Y
sum=sum+i i++
输出sum (总和)
2020/11/19
C语言程序设计教程
第四章 流程控制
12
❖源程序:
#include <stdio.h>
main()
{ int i,sum=0;
循环初值
i=1;
while(i<=100)
{ sum=sum+i;
循环变量增值
i++;
}
printf("%d",sum);
if (score<60)
count++;
i++;
} printf(“sum=%10.2f, count=%d\n",sum,count);
}
2020/11/19
C语言程序设计教程
第四章 流程控制
15
❖小结:
1)while语句先判断后执行循环语句。 2)while语句中的语句部分若为简单句可不用{}。 3)while语句的循环体中应有趋于结束的条件。 4)对于while循环而言,若表达式不成立语句部分 一次也不被执行。
}
循环条件
循环终值 循环体
2020/11/19
C语言程序设计教程
第四章 流程控制
13
练习:
思考 1、编程计算1~10的平方和
#include <stdio.h> main() { int i=1,sum=0;
文件包含 主函数
循环初值
执行过程
i
sum
1 0+1*1=1
2 1+2*2=5
相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

【输入】 第1行只包括一个100到120之间(包含100和120)的整数 (以厘米为单位),表示陶陶把手伸直的时候能够达到的最 大高度。 第2行包含10个100到200之间(包括100和200)的整数 (以厘米为单位)分别表示10个苹果到地面的高度,两个相 邻的整数之间用一个空格隔开。 【输出】 输出包括一行,这一行只包含一个整数,表示陶陶能够摘到 的苹果的数目。 【样例输入】 110 100 200 150 140 129 134 167 198 200 111 【样例输出】 5
var i,s:integer; begin s:=0; i:=0; while i<=300 do begin s:=s+i; i:=i+3; end; writeln(s); end.
二、循环结构的综合练习
1、陶陶摘苹果(NOIP2006p)
(apple.pas/c/cpp) 【问题描述】 陶陶家的院子里有一棵苹果树,每到秋天树上就会结 出10个苹果。苹果成熟的时候,陶陶就会跑去摘苹果。陶 陶有个30厘米高的板凳,当她不能直接用手摘到苹果的时 候,就会踩到板凳上再试试。 现在已知10个苹果到地面的高度,以及陶陶把手伸 直的时候能够达到的最大高度,请帮陶陶算一下她能够摘 到的苹果的数目。假设她碰到苹果,苹果就会掉下来。
var h,x,sum,i:integer; begin sum:=0; readln(h); h:=h+30; for i:=1 to 10 do begin read(x); if x<=h then inc(sum); end; writeln(sum); end.
2、灯的开关状态
有N个灯放成一排,从1到N依次顺序编号,开始时全部打开。 有N个人也从1到N依次编号。1号人将灯全部关闭,2号人将 凡是编号为2的倍数的灯打开;3号人将凡是编号为3的倍数的 灯作相反处理(该灯如为打开的, 则将它关闭;如关闭的,则 将它打开)。以后的人都和3号人一样,将凡是自己编号倍数的 灯作相反处理。 编程实现:第N个人操作后,按顺序输出灯的状态。(1-表示灯 打开,0-表示灯关闭) 输入:n(n<=100),灯的个数, 输出:灯的状态,01序列,中间无空格。 样例: 输入:2 输出:01
var n,i,s:longint; begin readln(n); s:=0; i:=1; while i<=n do begin if n mod i=0 then s:=s+1; i:=i+1; end; writeln(s); end.
例2:求s=3+6+9+……+300的值。
var i,s:integer; begin s:=0; for i:=1 to 100 do s:=s+3*i; writeln(s); 不能预先确定时,只能根据某一条件来决定是 否进行循环时,用while 语句实现。 格式: 循环体中必须有改变循环控 while <布尔表达式> do 制变量的语句,否则出现死 <一条语句:循环体>; 或: while <布尔表达式> do 循环。区别于for结构
begin
<语句组:循环体>
引例:
求恰好使s=1+1/2+1/3+…+1/n的值大于10时n的值。
var s : real; n : integer;{n分母} begin s:=0; n:=0; while s<=10 do{当s的值还未超过10时} begin n:=n+1;{分母1} s:=s+1/n;{将下一项值累加到s} end; writeln(n);{输出结果} end.
循环控制变量的改变可以不是1。但必须是整数。
3、能 用for的一定能用while实现。
例1、键入一个自然数N(<=106),求这个自然数 的因数的个数S(包含1和n)。
如: 输入: 6
输出:
4
var n,I,s:longint; begin readln(n); s:=0; for i:=1 to n do if n mod i=0 then s:=s+1; writeln(s); end.
最大公约数?
例2、输入n(<1015),求他的各位数字之和. 如: 输入: 1234 输出: 10
var n:int64; s,t:integer; begin readln(n); s:=0; while n<>0 do begin t:=n mod 10; s:=s+t; n:=n div 10; end; writeln(s); end.
end;
其意义为: 当布尔表达式的值为true时,执行do后面的语句。
例1: 求两个数a,b(<1000)的最小公倍数。 样例: 输入: 20 30 输出: 60
var a,b:integer; s:longint; begin readln(a,b); s:=a; while s mod b<>0 do s:=s+a; writeln(s); end.
Int64 :[-9*1018 , 9*1018] [ -9223372036854775808, 9223372036854775807]
For 与 while 的区别与联系:
1、for 必须能预先确定循环次数。 循环控制变量,每次自动加1,不能人为的改变。 2、while 可以不知道循环次数。 在循环体内必须有修改循环控制变量的语句,否则死循环。
算法分析:
初始状态:1111111111……1 先分析:编号为4、5、8、15、25、32、36……灯最后的状态
结论:编号为i的灯经过偶数次操作为1,奇数次操作为0.
编号i的灯的操作次数等于因数个数,只有完全平方数的因数 个数为奇数.所以判断第i个灯的状态:如果i是完全平方数则状 态为0,否则为1. var n,m,i:integer; begin readln(n); for i:=1 to n do begin m:=trunc(sqrt(i)); if m*m=i then write(0) else write(1); end; end.
相关文档
最新文档