C循环控制结构练习题_第1页
C循环控制结构练习题_第2页
C循环控制结构练习题_第3页
C循环控制结构练习题_第4页
C循环控制结构练习题_第5页
已阅读5页,还剩19页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、循环控制结构练习题1. 从键盘上输入一个正整数n,计算其阶乘n! #include <iostream>#include <cmath>using namespace std;int f(int n)int t = 1;for (int i = n; i > 0; i-)t = t*i;return t;(0的阶层为1)int main()int n;cout << "n="cin >> n;cout << endl;if (n < 0)n = abs(n);cout << "n!

2、="<<f(n);system("pause"); return 0;2. 从键盘上输入一个正整数n,判断是否是素数?法1: #include<iostream>#include <iomanip>using namespace std;void f(int n) int k = sqrt(n),i;for ( i = 2; i <= k; i+)if (n%i = 0)break;if (i >= k+1)cout << n << "是素数" << endl;

3、else cout << n << "不是素数" << endl;int main()int n;cout << "n="cin >> n;f(n);system("pause"); return 0;法2;#include<iostream>#include <iomanip>using namespace std;bool f(int n) int k = sqrt(n), i;for (i = 2; i <= k; i+)if (n%i =

4、 0)break;if (i >= k + 1)return 1;else return 0;int main()int n;cout << "n="cin >> n;f(n);if(f(n)cout << n << "是素数" << endl;else cout << n << "不是素数" << endl;system("pause"); return 0;bool f2(int n)int k=sqrt(n)

5、,i;for( i=2;i<=k;i+)if(n%i=0)return 0;if(i>=k+1)return 1;1int main()int n;while(1)cin>>n;if(n=0)break;if(f2(n)cout <<"是素数!"<<endl;system("pause");return 03.编写程序,输入一个整数,求该整数的各位数字和。 #include <iostream>#include <cmath>using namespace std;int f(int

6、 n)int t = 0;for (int i = n; i > 0; i=i/10)t=i%10+t;return t;int main()int n;cout << "n="cin >> n;if (n < 0)n = abs(n);cout << "n的各位数字和为:" << f(n) << endl;system("pause"); return 0;法二: int f(int n)if (n < 10)return n;else return (n

7、 % 10 + f(n / 10);int main()int n;cout << "n="cin >> n;if (n < 0)n = abs(n);cout << "n的各位数字和为:" << f(n) << endl;system("pause"); return 0;int f3(int n)n=abs(n);if(n<10)return n;else return (n%10)+f3(n/10);int main()int n;while(1)cin&g

8、t;>n;if(n=0)break;cout <<f3(n);system("pause");return 0;3. 编写程序,输入一个整数,求该整数的各位数字的乘积。法一:#include <iostream>using namespace std;int f(int n)if (n < 10)return n;else return (n % 10 )* f(n / 10);int main()int n;cout << "n="cin >> n;n = abs(n);cout <&l

9、t; f(n);system("pause");return 0;法二:#include <iostream>using namespace std;int f(int n)int t = 1;for (int i = n; i > 0; i = i / 10)t = t*(i % 10);return t;int main()int n;cout << "n="cin >> n;n = abs(n);cout << f(n);system("pause");return 0;in

10、t f4(int n)n=abs(n);if(n<10)return n;else return (n%10)*f3(n/10);int main()int n;while(1)cin>>n;if(n=0)break;cout <<f4(n);system("pause");return 0;4. 编写程序,输入一个整数,求该整数的各位数字的平方和。法一: #include <iostream>using namespace std;int f(int n)int t = 0;for (int i = n; i > 0; i

11、= i / 10)t = t+(i % 10)*(i%10);return t;int main()int n;cout << "n="cin >> n;n = abs(n);cout << f(n);system("pause");return 0;法二:#include <iostream>using namespace std;int f(int n)if (n < 10)return n*n;else return (n % 10)*(n % 10)+f(n / 10);int main()i

12、nt n;cout << "n="cin >> n;n = abs(n);cout << f(n);system("pause");return 0; int f4(int n)n=abs(n);if(n<10)return n*n;if(n>10)return (n%10)*(n%10)+f4(n/10); int main()int n;while(1)cin>>n;if(n=0)break;cout <<f4(n)<<endl;system("pause&

13、quot;);return 0;5. 编写程序,输入一个整数,求该整数的各位上的数字是否包含数字5,若有则输出是第几位有含数字5. #include <iostream>using namespace std;void f(int n)int j = 0;for (int i = n; i > 0; i = i / 10)j+;if (i % 10 = 5)cout << j << " "int main()int n;cout << "n="cin >> n;n = abs(n);cou

14、t << "包含5的位置i为:"f(n);cout << endl;system("pause");return 0;void f5(int n,int m)for(int i=n,j=0;i>0;i=i/10,j+)if(i%10=m)cout <<"第"<<j+1<<"位"<<endl;int main()int n,m;while(1)cin>>n>>m;if(n=0)break;f5(n,m);system

15、("pause");return 0;6. 编写程序输出一个平行四边行。注:边长为10个*号 void u()int i = 0;for (int i = 1; i <= 10; i+)cout << setw( i);for (int j = 1; j <= 10; j+)cout << '*'cout << endl; void f6()for(int j=0;j<10;j+)cout<<setw(20+j);for(int i=0;i<10;i+)cout<<'

16、*'cout <<endl;int main()int n,m;f6();system("pause");return 0;8.编程计算:的前20项的和。法一: #include <iostream>using namespace std;double f(double n)if (n > 0) if (n = 1)return 1;else return n / (2 * n - 1) + f(n - 1);int main()int n;cout << "n="cin >> n;n = a

17、bs(n);cout << f(n);cout << endl;system("pause");return 0;double f7(double n)int i;if(n>0)if(n=1)return 1;else return (n/(2*n-1)+f7(n-1);int main()double n,m;cin>>n;cout <<f7(n);system("pause");return 0;9.编写一程序,输入一个正整数,统计该数中含数字5的个数。 using namespace std;v

18、oid f(int n)int j = 0;for (int i = n; i > 0; i = i / 10)if (i % 10 = 5)j+;cout <<j<<endl;int main()int n;cout << "n="cin >> n;n = abs(n);cout << "包含5的个数为:"f(n);cout << endl;system("pause");return 0;10.编写程序,输出所有含数字5且为77倍数的四位数。 void

19、J() for(int i=1000;i<=9999;i+)if (i % 77 = 0) int m = i;for(m;m>0;m=m/10)if (m % 10 = 5) cout << i << " " break; int main()J();System(“pause”);return 0;11.编写一程序,输入一个正整数n,求大于等于n的最小素数。#include<iostream>using namespace std; int main()int x, b, i, m, k;cout << &qu

20、ot;请输入一个整数:"cin >> x;b = sqrt(x);for (i = 2; i <= b;i+)if (x%i = 0) break;if (i >= b+ 1) cout << x << endl;else for (m = x; m+)k = sqrt(m);for (i = 2; i <= k;i+)if (m%i = 0)break;if (i >= k + 1)cout << m << " "break;system("pause");r

21、eturn 0;法二:#include <iostream>using namespace std;int main()int n, k, m, i, j;cout << "n="cin >> n;for (i = n; i+)for (j = 2; j*j<i; j+)if (i%j = 0)break;if (j*j >= i)cout << i << endl;break;system("pause");return 0;12.从键盘输入一个小于15的正整数,计算其阶乘。13.

22、编程计算1!+2!+3!+.+n!。n从键盘输入。int sum2(int n)int sum=0,t=1;for(int j=1;j<=n;j+)t=1;for(int i=1;i<=j;i+)t=t*i;sum=sum+t;return sum;int main()int n;while(1)cin>>n;if(n=0)break;cout <<"sum="<<sum2(n)<<endl;system("pause");return 0;14.从键盘上输入一个正整数m,找出1000至1000

23、0之间所有各位数字之和等于m的数。如输入32,则有9869满足要求。因为9869各位上数字之和等于32。#include <iostream>using namespace std;void f(int m)int i;for (i = 1000; i < 10000; i+)int sum = 0;for (int j = i; j>0; j = j / 10) sum = sum + j % 10; if (sum = m) cout << i << " " cout << endl;int main()int

24、 n, m;cout << "n="cin >> n;f(n);system("pause");return 0;15.已知xxz+yzz=532,求所有可能的x,y,z的值#include <iostream>using namespace std;int main()for (int x = 0; x <= 9; x+)for (int y = 0; y <= 9; y+)for (int z = 0; z <= 9; z+)int k = x * 10 + x * 100 + z + y * 1

25、00 + z * 10 + z;if (k = 532)cout << x << " " << y << " " << z << " " << endl;system("pause");return 0;16.编程从键盘中随机输入若干整数,统计其中正整数、0、负整数数的个数。当输入整数100000时结束输入。#include <iostream>using namespace std;void main()int n=0

26、,m=0,k=0,c=0;while (n != 100000)cout << "n="cin >> n; if (n > 0)k+;else if (n = 0)m+;else if (n < 0)c+;cout << "正整数的个数是:" << k << endl;cout << "负整数的个数是:" << k << endl;cout << "0的个数是:" << k <&

27、lt; endl;system("pause");17.编写一程序,输入一个正整数n,求小于等于n的最大素数。18.求100999中的。所谓水仙花数是指一个三位数,它的每位数字的立方之和等于该数。例如,因为153135333,所以153为水仙花数。#include <iostream>using namespace std;void main()int i;for (i = 100; i <= 999; i+)int j, sum = 0;j = i;while (j)intk = j % 10;sum = sum + k*k*k;j = j / 10;i

28、f (sum = i)cout << sum << " "system("pause");19.求1000之内的所有完数。所谓完数是指一个数恰好等于它的所有因子之和。例如,6123,所以6为完数。20. 编一程序显示如下图案:* * * * * * * * * * * * * * * * * * * * *21.编一程序显示如下图案:AA B CA B C D E #include<iostream>#include <iomanip>using namespace std;void f(int n) fo

29、r (int i = 1; i <= n; i+) cout << setw(20 - i);for (int j = 0; j < 2 * i - 1; j+)char t = 'A'+j;cout << t;cout << endl;int main()f(3);system("pause"); return 0;21.根据/4 =1-1/3+1/5-1/7+求的近似值,直到最后一项的值小于0.000001为止。22. 猴子吃桃问题。猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个。第二天早上

30、又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,发现只剩一个桃子了,求猴子第一天究竟摘了多少个桃子?23.编程序模拟剪刀,石头和纸游戏。游戏规则为:剪刀剪纸,石头砸剪刀,纸包石头玩游戏者从键盘上输入s (表示剪刀)或(表示石头)或(表示纸),要求两个游戏者交替输入,计算机给出输赢的信息。 24.编写程序输出菲波那切数列的前20项。即前两项为1,以后每一项为前两项之和。25.打印九九乘法表。26.若一头小母牛,从出生起第四个年头开始每年生一头母牛,按此规律,第n年时有多少头母牛?27.编写程序,输入一个整数,求该整数是几位数?并输出最高位数

31、字。 #include <iostream>using namespace std;int f(int n)int x = 0,j=0;for (int i = n; i > 0; i = i / 10) j+;if (x < i % 10)x = i % 10;cout << j << endl;return x;int main()int n;cout << "n="cin >> n;n = abs(n);cout << f(n);cout << endl;system(&q

32、uot;pause");return 0;28.从键盘上输入一个正整数n,求出5位数中各位数字之和等于n的所有素数,每行按6个素数输出。法一: #include <iostream>(错误)using namespace std;void f(int m, int n, int k)int l = 0;for (int i = m; i <= n; i+) int s = 0;for (int j = i; j > 0; j = j / 10)s = s + j % 10;if (s = k) int t, z = sqrt(i);for (t = 2; t

33、<= k; t+)if (i%t = 0)break;if (t >= k + 1) cout << i << " "l+;if (l % 6= 0)cout << endl;int main()f(10000, 99999, 43);system("pause"); return 0;法二:(正确)#include <iostream>using namespace std;void foundPrime(int n)int k = 0;for (int i = 10000; i<100

34、000; i+)int s = 0;int m = i;while (m>0)s = s + m % 10;m = m / 10;if (s = n)int z = sqrt(i);int j;for (j = 2; j <= z; j+) if (i%j = 0) break;if (j >= z + 1)cout << i << " "k+;if (k % 6 = 0) cout << endl;int main()foundPrime( 43);system("pause");return 0;

35、29.编程求下式的值:n1+n2+n3+n4+n10,其中n=1,2,3。编写函数时,设置参数n的默认值为2。 #include <iostream>using namespace std;int f( int n=2)int i, t = 1, sum = 0,k=0;for (i = 1; i <=10; i+)t = t * n;sum = sum + t;return sum;int main()cout << f() << endl;cout << f(1) << endl;cout << f(2) <

36、;< endl;cout << f(3) << endl;system("pause"); return 0;30.给定求组合数公式为:Cnm = m!/ n! (m-n)!编一程序,输入m 和n的值31.求s=1+(1+2)+(1+2+3)+.+(1+2+3+n)的值。 #include <iostream>using namespace std;int f(int n)int sum, t = 0;for (int j = 1; j <= n; j+) sum = 0;for (int i = j; i > 0; i

37、-)sum = sum + i;t = t + sum;return t;int main()int n;cout << "n="cin >> n;n = abs(n);cout << f(n);cout << endl;system("pause");return 0;32.编程计算:s=33.求sum=a+aa+aaa+aaaa+aaa(表示n个a)的值。其中a是一位数字。例如当n=6,a=2时sum=2+22+222+2222+22222+222222。n和a的值由键盘输入。法一: #include

38、<iostream>using namespace std;int f(int a, int n)int i, t = 1, sum = 0,k=0;for (i = 0; i <n; i+)sum = sum + pow(10, i)*a;k = k + sum;return k;int main()cout << f(2, 2) << endl;system("pause"); return 0; 法二:#include <iostream>using namespace std;int f(int a, int n

39、)int i, t = 1, sum = 0,k=0;for (i = 0; i <n; i+)k = k + a*t;sum = sum + k;t = t * 10;return sum;int main()cout << f(2, 3) << endl;system("pause"); return 0;34.求100230之间所有素数的和。 #include<iostream>#include <iomanip>using namespace std;void f() int t = 0;for (int j =

40、 100; j < 230; j+)int k = sqrt(j);int i;for (i = 2; i <= k; i+)if (j%i = 0)break;if (i >= k + 1) cout << j<< " " t+;if (t % 6 = 0)cout << endl;int main()f();system("pause");return 0; int sum(int n,int m)int sum=0;for(int i=n;i<=m;i+)int k=sqrt(i),j;f

41、or( j=2;j<=k;j+)if(i%j=0)break;if(j>=k+1)sum=sum+i;return sum;int main()cout <<sum(100,230);system("pause");return 0;35.从键盘上输入若干整数,计算并输出其中正整数的平均值,以0作为输入结束标志。(要求分别使用while语句、do while语句编写)36.编程实现下面的图案。* * * * * *37.实现一个简单的菜单程序,运行时显示:Menu:A(阶乘)S(求和) F(找素数)Q(退出) 请选择(A/S/F/Q)?当选择A时,输

42、出”求阶乘”信息;选择S时,输出”求和”信息;选择F时,输出”找素数”信息;选择Q时,退出循环,结束程序。#include <iostream>#include <iomanip>using namespace std;void menu()cout <<"-Menue-"<<endl;cout <<setw(15)<<"A.求阶乘"<<endl;cout <<setw(13)<<"S.求和"<<endl;cout

43、<<setw(15)<<"F.找素数"<<endl;cout <<setw(13)<<"Q.退出"<<endl;int sum(int n)int sum=0;for(int i=n;i>0;i=i/10)sum=sum+i%10;return sum;int AA(int n)int t=1;for(int i=1;i<=n;i+)t=t*i;return t;void k3(int n)int k=sqrt(n);int i;for(i=2;i<=k;i+)if

44、(n%i=0)cout <<"不是素数!"<<endl;if(i>=k+1)cout <<"是素数!"<<endl;void choice()char ch;int n;while(1)menu();cout <<"请输入数字:"cin>>n;cout <<"请输入查找的序号:"cin>>ch;switch(ch)case 'A':cout <<AA(n);break;case '

45、;S':cout <<sum(n);break;case 'F':k3(n);break;case 'Q':break;int main()choice();system("pause");return 0;38.编程找出所有的三位整数中各位数字之和为素数的所有三位数,每行输出5个。39.编程实现如下图案 ststststststststststststs stststststststststststs ststststststststststs stststststststststs ststststststststs

46、stststststststs ststststststs stststststs ststststs stststs ststs sts S40.编程实现如下图案 A B B C C D D E E F F G G HHHHHHHHHHHHHHH41.编程实现如下图案 A B B C C D D E E F F G G HHHHHHHHHHHHHHH G G F F E E D D C C B B Avoid printABCD()int j;/上半部分 for(int i=1;i<=8;i+) cout<<setw(20-i); for( j=1;j<=2*i-1;

47、j+) if(j=1 | j=2*i-1) cout<<(char)('A'+i-1); else if(i=8) cout<<(char)('A'+i-1); else cout<<" " cout<<endl; 42. 从键盘上输入一个整数,判断该数是否为回文数。所谓的回文数就是从左到右读与从右到左读都是一样的数。如7887、23432就是回文数。 #include<iostream>#include <iostream>using namespace std;void f(int n)int j = 0,t=0;for (int i = n; i > 0; i =

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论