1、 for(j=0;jj+) printf( 【设计型】5.3 编程计算编写程序,输入n的值,求 :1-1/2+1/3-1/4+1/5-1/6+1/7-.+1/n (保留四位小数) double n,i,sum,k=1.0;%lfn); i=1,sum=0; while(i=n) sum=sum+k/i; i+; k=-k;(用这个式子实现正负交替) printf(sum=%.4lfn,sum); return 0;【设计型】5.4 分数序列有一个分数序列:.,输入整数n,求出其前n项的和。 输出语句格式为:sum=%16.10fn,s); int n,a,b,i,temp; double su
2、m; i=1,sum=0,a=2,b=1; sum=sum+a*1.0/b; temp=a; a=a+b; b=temp;(几个式子实现数值的变换)【设计型】5.5 求e的值编写程序,从键盘输入整数 n , 求 e 的值 . e=1+1/1!+1/2!+1/3!+.+1/n! 注意:用 double 型数据计算输出语句: int n,i; double sum,jc; i=1,sum注意题干中的红色1=1.0 jc=1.0; jc=jc*i; sum=sum+1.0/jc;【设计型】5.6 最大公约数输入两个正整数m和n,求它们的最大公约数和最小公倍数比如,输入m和n的值分别为14和21,则最
3、大公约数为7,最小公倍数为42。 int yu,m,n,temp,bei,ji;%d%dm,& if(mn) temp=m,m=n,n=temp; ji=m*n; yu=m%n; while(yu!=0) m=n; n=yu; yu=m%n; (最大公约数求法) bei=ji/n;(最小公倍数求法)the greatest common divisor is %dn,n);the least common multiple is %dn,bei);【设计型】5.7 水仙花数输出所有的水仙花数。所谓的水仙花数是指一个3位数,其各位数字立方和等于该数本身。例如153是一水仙花数,因为153=13+
4、53+33输出语句:%dn int a,b,i,j,k;=9; for(k=0;kk+) (三重循环从1到999) a=i*i*i+j*j*j+k*k*k; b=100*i+10*j+k; if(a=b) printf(,b); 【设计型】5.8 完数一个数如果恰好等于它的因子之和,这个数就称为完数。例如,6的因子为1,2,3,且6=1+2+3,因此6是完数,从键盘上输入一个正整数,判断其是否为完数。如果是,则按照如下格式输出。比如,输入6,则输出Yes,its factors are 1 2 3;如果输入8,则输出No int yinzi,num,i,sum=0; for(yinzi=1;
5、yinzi yinzi+) if(num%yinzi=0) sum=sum+yinzi; if(sum=num)Yes,its factors are for(i=1; i i+) if(num%i=0) printf( %d,i); (输出因子具体值) else printf(Non return 0;【设计型】5.9 素数输入两个正整数m和n,求出m,n区间的所有素数 int m,n,i,j,tag=1; for(i=m;=n; for(j=2; j0) min=min*10+(int)max%10;(将数字反过来) max=max/10; if(num=min)Yesn else pri
6、ntf(return 0;【设计型】5.11 贪吃的猴子有一只猴子,第一天摘了若干个桃子 ,当即吃了一半,但还觉得不过瘾 ,就又多吃了一个。第2天早上又将剩下的桃子吃掉一半,还是觉得不过瘾,就又多吃了两个。以后每天早上都吃了前一天剩下的一半加天数个(例如,第5天吃了前一天剩下的一半加5个)。到第n天早上再想吃的时候,就只剩下一个桃子了。天数n第一天的桃子个数,输出语句为printf(The monkey got %d peachs in first day.nSmaple:Input:5OutputThe monkey got 114 peachs in first day.提示:问题分析:总
7、共 t0 日 吃掉 剩余 1 t0/2+1 t0-(t0/2+1)=t0/2-1 t1=t0/2-1 =t0=(t1+1)*2 2 t1/2+2 t1-(t1/2+2)=t1/2-2 t2=t1/2-2 =t1=(t2+2)*2 . n-1 tn-2/2+(n-1) tn-2-(tn-2/2+(n-1)=tn-2/2-(n-1) tn-1=tn-2/2-(n-1) = tn-2= (tn-1+n-1)*2 n 1 0 tn-1=1 int i,t,sum;t); sum=1; for(i=t;i1;i-) sum=(sum+i-1)*2;?【创新型】5.12 马戏团观众人数一个马戏团表演, n
8、 个座位全满,全部门票收入是 120 元,现在知道,男人每人 5 元,女人每人 2 元,小孩每人 1 角。编程,输入总人数 n ,输出满足要求的男人、女人和小孩人数的全部方案。若 n 人无法满足条件,则输出“No outputn”。 人数 n 男人、女人和小孩人数 int man,woman,child,total,sum,tag=0;total); for(man=0; man=total; man+) for(woman=0; woman double x,a,b; double i;x); b=x;) a=i; i=(i+x/i)/2; if(fabs(i-a) double x0,x1
9、; for(x1=0; x0=x1; x1=cos(x0); if(fabs(x0-x1)=0.000001)x=%lfn,x1);【设计型】5.15 求一个三位数,其值等于其各位阶乘之和编写程序,求某三位数,该数值的大小正好是组成这个数的三个位上的数字阶乘之和。输出格式:,num); int i,j,k,l,ge,shi,bai,s1,s2,s3; for(i=100;=999; ge=i%10; shi=i%100/10; bai=i/100; s1=1; s2=1; s3=1; for(j=1;=ge; s1=s1*j; for(k=1; k=shi; k+) s2=s2*k; for(
10、l=1; l=bai; l+) s3=s3*l; if(i=s1+s2+s3)【研究创新型】6.1 谁能出线背景:电视台举办“超级学生”才艺大赛,由于报名人数狂多,所以要先进行分组预赛。按规定,每10名学生为一个预赛小组,评委打出分数(0100分),各小组第一名可以进入下一轮;如果有多名学生得分相同都是第一名,则可同时进入下一轮。按顺序给出一个小组10个人的最后得分(int)。能够出线的学生序号(09)。int i,a10,max;for(i=0;10;scanf(ai);max=a0;if(max=ai)max=ai;if(ai=max) printf( return 0;【设计型】6.2 统计素数的个数求出 2 到 m 之间 ( 含 m,mai+1) z=ai+1; ai+1=ai; ai=z;,aj);【设计型】6.4 插入法排序如果一个数组中保存的元素是有序的(由小到大),向这个数组中插入一个数,使得插入后的数组元素依然保持有序。定义一个数组,长度为11,初始元素为10个,按照从小到大的方式输入,然后输入一个要插入的元素,使得插入后仍然有序。
copyright@ 2008-2023 冰点文库 网站版权所有
经营许可证编号:鄂ICP备19020893号-2