书签 分享 收藏 举报 版权申诉 / 37
上传文档赚钱

类型《循环结构程序设计》课件2.pptx

  • 上传人(卖家):晟晟文业
  • 文档编号:4142774
  • 上传时间:2022-11-14
  • 格式:PPTX
  • 页数:37
  • 大小:1.03MB
  • 【下载声明】
    1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
    2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
    3. 本页资料《《循环结构程序设计》课件2.pptx》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
    4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
    5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
    配套讲稿:

    如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。

    特殊限制:

    部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。

    关 键  词:
    循环结构程序设计 循环 结构 程序设计 课件
    资源描述:

    1、第第3 3讲循环结构程序设计讲循环结构程序设计循环的定义p反复执行相同的语句序列反复执行相同的语句序列条件条件A真真假假条件条件A真真假假while循环p格式:格式:while(while(表达式表达式)语句序列语句序列 表达式表达式语句序列语句序列非非00p语句序列称为循环体,当为一条语句时,表示复合语句的语句序列称为循环体,当为一条语句时,表示复合语句的可以省略。可以省略。p表达式可以为任何类型表达式可以为任何类型p先判断,后执行,若条件不成立,有可能一次也不执行。先判断,后执行,若条件不成立,有可能一次也不执行。p语句序列中必须有改变语句序列中必须有改变whilewhile后面括号的表达

    2、式值的语句,否则有可能死循环后面括号的表达式值的语句,否则有可能死循环。问题描述:笑笑作为数学课代表,每次考试后,数学老师都会让他统计成绩,老师并不关心具体某个人的成绩,而只关心参加考试的人数、平均成绩、最低分和最高分。输入要求:第1行输入T,表示组数,第二行输入一些 整数,表示学生的成绩,每个数之间用一个空格分开,-1表示输入结束。输出要求:占4行,第一行表示学生人数n,第二行表示最高分,第三行表示最低分,第四行表示平均分,其中只有平均分是小数(只保留一位小数),其余为整数 输入实例:1 50 90 87 67 84 99 56 74 82 94-1输出实例:10 100 50 78.3回文

    3、数p 问题描述:输入一个整数,判断一个该数是否为回文数。问题描述:输入一个整数,判断一个该数是否为回文数。p 输入要求:输入一系列的整数输入要求:输入一系列的整数n n,n100000000n100000000p 输出要求:如果是回文数输出输出要求:如果是回文数输出YesYes,如果不是回文数输出,如果不是回文数输出NoNop 输入样例:输入样例:12341234 121121 -12321-12321 100100p 输出样例:输出样例:NoNo YesYes YesYes NoNo 素数因子 问题描述:输入一个整数,输出它的所有素数因子 输入要求:输入一系列的整数(0,1,-1除外),每行

    4、一个 输出要求:输出所有的素数因子,每个因子之间用1个空格分开,最后一个因子后面没有空格 输入样例:8 30 125 输出样例:2 2 2 2 3 5 5 5 5#includeusing namespace std;int main()int m,k=2;cinm;if(m0)cout-;m=-m;while(km)if(m%k=0)coutk;m=m/k;elsek+;coutmendl;return 0;6174数字黑洞 问题描述:任意一个每位数字不完全相同的4位正整数,将各位上数字重新组合成一个最大数和一个最小数相减,重复这个过程,必定得到6174。输入要求:输入一系列的4位正整数,占

    5、一行。输出要求:占一行,最终得到6174的变换次数。输入样例:1234 1000 6174 输出样例:3 5 0爱因斯坦走楼梯:有一条长阶梯,若每步跨2阶,则最后剩1阶;若每步跨3阶,则最后剩2阶;若每步跨5阶,则最后剩4阶;若每步跨6阶,则最后剩5阶;若每步跨7阶,则最后正好一阶不剩;问该楼梯最少有多少阶?#includeusing namespace std;int main()int n=7;while(n%2!=1)|(n%3!=2)|(n%5!=4)|(n%6!=5)n=n+7;coutnendl;return 0;#includeusing namespace std;int ma

    6、in()int n=7;while(!(n%2=1)&(n%3=2)&(n%5=4)&(n%6=5)n=n+7;coutnendl;return 0;do while 循环语句p格式:格式:dodo 语句序列语句序列 while(while(表达式表达式);表达式表达式语句序列语句序列非非00最大公约数和最小公倍数p 问题描述:从键盘上输入两个整数,求它们的最大公约数和最小问题描述:从键盘上输入两个整数,求它们的最大公约数和最小公倍数。公倍数。p 输入要求:每行输入两个整数,每个整数之间用一个空格分开。输入要求:每行输入两个整数,每个整数之间用一个空格分开。p 输出要求:第一行输出最大公约数,

    7、第二行输出最小公倍数输出要求:第一行输出最大公约数,第二行输出最小公倍数p 输入样例:输入样例:3 63 6 24 13 24 13p 输出样例:输出样例:3 3 6 6 1 1 312 312开始开始输入输入a,br=a%ba=bb=rr!=0输出输出a结束结束非非00 问题描述:计算与正整数n相等的二进制代码中有1和0的个数。输入要求:输入一些正整数,每个占一行 输出要求:占两行,第一行是1的个数,第二行是0的个数。输入样例:8 93 输出样例:1 3 5 2Cantor表问题描述:现代数学的著名证明之一是问题描述:现代数学的著名证明之一是Georg CantorGeorg Cantor证

    8、明了有理数是证明了有理数是可以枚举的。他利用下面一张表来证明这一命题:可以枚举的。他利用下面一张表来证明这一命题:1/1 1/2 1/3 1/4 1/5 1/1 1/2 1/3 1/4 1/5 2/1 2/2 2/3 2/42/1 2/2 2/3 2/43/1 3/2 3/3 3/1 3/2 3/3 4/1 4/2 4/1 4/2 5/1 5/1 我们以我们以Z Z字型给上表每一项编号字型给上表每一项编号 。第。第1 1项是项是1/1 1/1,然后第,然后第2 2项是项是1/21/2,2/2/1 1,3/13/1,2/2.2/2.输入描述:整数输入描述:整数N N(1N100000001N10

    9、000000)输出描述:表中的第输出描述:表中的第N N项项 样例输入:样例输入:7 7样例输出:样例输出:1/41/4#includeusing namespace std;int main()int n,i,j;cinn;i=0;/斜线序号j=n;/第n项在某行的位置doi+;j=j-i;while(j0);j=j+i;if(i%2=0)coutj/i+1-jendl;else couti+1-j/jendl;return 0;角谷猜想 问题描述:定义这样一个整数函数f(n),当n是偶数时,f(n)=n/2;当n是奇数时,f(n)=(3n+1)/2。这个猜想是说:对于任意的整数n,计算f(

    10、n),f(f(n),f(f(f(n),.,若干步之后,总会得到1。对于给定的n,求出数字序列中第一次出现1的步数。输入要求:输入一些正整数n,每个正整数占一行。输出要求:占一行,输出对应n得到1的步数。输入样例:5 10 输出样例:4 5pwhilewhile语句和语句和dowhiledowhile语句语句 比较比较n whilewhile语句是先判断后执行,只要不满足条件,循环体语语句是先判断后执行,只要不满足条件,循环体语句根本不会执行句根本不会执行 n dowhiledowhile语句是先执行后判断,不管条件是否满足,循语句是先执行后判断,不管条件是否满足,循环体语句总会执行一次环体语句

    11、总会执行一次#include using namespace std;int main()int i,sum=0;cini;while(i=10)sum+=i;i+;coutsumendl;return 0;#include using namespace std;int main()int i,sum=0;cini;do sum+=i;i+;while(i=10);coutsumendl;return 0;for循环语句p格式:格式:for(for(1;2;)3)语句序列语句序列 表达式表达式2表达式表达式1非非00表达式表达式3语句序列语句序列p语句序列称为循环体。语句序列称为循环体。p当

    12、语句序列只有单条语句,表示复合语句的当语句序列只有单条语句,表示复合语句的可以省略。可以省略。p表达式表达式1 1一般为赋值表达式,给控制变量赋初值;如果省略表达式一般为赋值表达式,给控制变量赋初值;如果省略表达式1 1,这时,这时forfor语句为如语句为如p表达式表达式2 2一般为关系表达式或逻辑表达式,称为循环控制条件一般为关系表达式或逻辑表达式,称为循环控制条件p表达式表达式3 3一般为赋值表达式,给控制变量增量或减量一般为赋值表达式,给控制变量增量或减量pforfor(;)。(;)。转移语句continue语句形式:continue;功能:结束本次循环,开始下一次循环continue

    13、只能用在循环结构中,而不能用于其它控制结构 表表 达达 式式 1表表 达达 式式 2 语语 句句 序序 列列 1语语 句句 序序 列列 2后后 续续 语语 句句非非 0非非 000continue#includeusing namespace std;int main()int k;for(k=100;k=200;k+)if(k%3=0)continue;coutk“;return 0;break语句 格式:break;功能:跳出switch结构或结束本层循环。说明:break语句只能用于switch或循环结构中 表达式表达式1表达式表达式2 语句序列语句序列1语句序列语句序列2后续语句后续语

    14、句非非0非非000break#includeusing namespace std;#define PI 3.1415926int main()int r;double area;for(r=1;r100.0)break;coutareaendl;return 0;阶乘之和问题描述:求非负整数的阶乘之和问题描述:求非负整数的阶乘之和输入要求:输入一个非负整数输入要求:输入一个非负整数n(n13)n(n13),占一行,占一行输出要求:占一行,阶乘的和输出要求:占一行,阶乘的和输入样例:输入样例:0 0 5 5 1212输出样例:输出样例:1 1 154154 522956314522956314

    15、#include#includeusing namespace std;int main()int i,sum,p,n;while(cinn)sum=0;p=1;if(n0)exit(0);for(i=1;i=n;i+)p=p*i;sum=sum+p;coutsum+1endl;return 0;分数数列p问题描述:已知分数数列问题描述:已知分数数列 2/12/1,-3/2-3/2,5/35/3,-8/58/5,对于输入的正整数对于输入的正整数n n,输出对应项的分数。,输出对应项的分数。p输入要求:输入一些输入要求:输入一些 正整数正整数n(n50)n(n50),分别占一行。,分别占一行。p

    16、输出要求:占一行,表示分数数列中的对应项。输出要求:占一行,表示分数数列中的对应项。p输入样例:输入样例:3 3 26 26p输出样例:输出样例:5/35/3 -317811/196418 -317811/196418#includeusing namespace std;int main()int a=2,b=1,i;int n;cinn;for(i=2;i=n;i+)a=a+b;b=a-b;if(n%2=0)cout-1*a/bendl;else couta/b4)(4),每个数占一行。,每个数占一行。p输出要求:占一行,两个素数的和。输出要求:占一行,两个素数的和。p输入样例:输入样例:

    17、4 4 20 20p输出样例:输出样例:2+22+2 3+17 3+17开开始始输输入入np=1p=p+1q=n-pp是是素素数数q是是素素数数p_flag=1p_flag=0q_flag=1q_flag=0p_flag*q_flag=0输输出出p和和q结结束束非非00非非00非非00#include#include#includeusing namespace std;int main()int i,p,q,n,p_flag,q_flag;while(cinn)if(n%2=1)|n4)/cout数据输入出错n”;exit(0);p=1;dop=p+1;q=n-p;p_flag=1;for(

    18、i=2;i=sqrt(p);i+)if(p%i=0)p_flag=0;break;q_flag=1;if(p_flag=1)for(i=2;i=sqrt(q);i+)if(q%i=0)q_flag=0;break;while(p_flag*q_flag=0);coutp+qendl;return 0;绝对素数p 问题描述:如果一个正整数是素数,它的反位数也是素问题描述:如果一个正整数是素数,它的反位数也是素数,这称这样的数为绝对素数数,这称这样的数为绝对素数。p 输入要求:输入一些正整数输入要求:输入一些正整数n n,每个占一行,每个占一行p 输出要求:占一行,输出输出要求:占一行,输出1 1

    19、到到n n之间名绝对素数的个数。之间名绝对素数的个数。p 输入样例:输入样例:1010p 20 20p 输出样例:输出样例:p 4 4p 7 7#include#includeusing namespace std;int main()int i,j,k,m,flag1=0,flag2=0,ans=0,n,p;cinn;for(i=2;i=n;i+)m=sqrt(i);for(j=2;jm)flag1=1;if(flag1=1)p=i;k=0;while(p)k=k*10+p%10;p=p/10;m=sqrt(k);for(j=2;jm)flag2=1;if(flag1*flag2=1)ans+;coutansendl;return 0;可编辑感谢下感谢下载载可编辑感感谢谢下下载载

    展开阅读全文
    提示  163文库所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
    关于本文
    本文标题:《循环结构程序设计》课件2.pptx
    链接地址:https://www.163wenku.com/p-4142774.html

    Copyright@ 2017-2037 Www.163WenKu.Com  网站版权所有  |  资源地图   
    IPC备案号:蜀ICP备2021032737号  | 川公网安备 51099002000191号


    侵权投诉QQ:3464097650  资料上传QQ:3464097650
       


    【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。

    163文库