当前位置:文档之家› 中国石油大学(华东)C语言习题答案

中国石油大学(华东)C语言习题答案

C语言复习题【设计型】5.1 输出一行星号编写程序在一行中输出 N 个星号。

输入: N值输出:一行中N个星号#include<stdio.h>int main(){int a,i;scanf("%d",&a);for(i=1;i<=a;i++)printf("*");printf("\n");return 0;}【设计型】5.2 打印平行四边形输入图形的高 n ,输出如下例( n=5 )所示的图形 .*************************输入:整数n例如 5输出:由*组成的高为5的平行四边形#include<stdio.h>int main(){int i,j,num;scanf("%d",&num);for(i=0;i<num;i++){for(j=0;j<num;j++)printf("*");printf("\n");}return 0;}【设计型】5.3 编程计算编写程序,输入n的值,求 :1-1/2+1/3-1/4+1/5-1/6+1/7-...+1/n (保留四位小数)#include<stdio.h>int main(){double n,i,sum,k=1.0;scanf("%lf",&n);i=1,sum=0;while(i<=n){sum=sum+k/i;i++;k=-k;(用这个式子实现正负交替)}printf("sum=%.4lf\n",sum);return 0;}【设计型】5.4 分数序列有一个分数序列:...............,输入整数n,求出其前n项的和。

输出语句格式为:printf("sum=%16.10f\n",s);#include<stdio.h>int main(){int n,a,b,i,temp;double sum;scanf("%d",&n);i=1,sum=0,a=2,b=1;while(i<=n){sum=sum+a*1.0/b;temp=a;a=a+b;b=temp;(几个式子实现数值的变换)i++;}printf("sum=%16.10f\n",sum);return 0;}【设计型】5.5 求e的值编写程序,从键盘输入整数 n , 求 e 的值 . e=1+1/1!+1/2!+1/3!+..+1/n! 注意:用 double 型数据计算输出语句:printf("sum=%16.10f\n",sum);#include<stdio.h>int main(){int n,i;double sum,jc;scanf("%d",&n);i=1,sum=1.0 jc=1.0;while(i<=n){jc=jc*i;sum=sum+1.0/jc;i++;}printf("sum=%16.10f\n",sum);return 0;}【设计型】5.6 最大公约数输入两个正整数m和n,求它们的最大公约数和最小公倍数比如,输入m和n的值分别为14和21,则最大公约数为7,最小公倍数为42。

#include<stdio.h>int main(){int yu,m,n,temp,bei,ji;scanf("%d%d",&m,&n);if(m<n)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;(最小公倍数求法)printf("the greatest common divisor is %d\n",n);printf("the least common multiple is %d\n",bei);return 0;}【设计型】5.7 水仙花数输出所有的水仙花数。

所谓的水仙花数是指一个3位数,其各位数字立方和等于该数本身。

例如153是一水仙花数,因为153=13+53+33输出语句:printf("%d\n",n);#include<stdio.h>int main(){int a,b,i,j,k;for(i=1;i<=9;i++){for(j=0;j<=9;j++){for(k=0;k<=9;k++) (三重循环从1到999){a=i*i*i+j*j*j+k*k*k;b=100*i+10*j+k;if(a==b)printf("%d\n",b);}}}return 0;}【设计型】5.8 完数一个数如果恰好等于它的因子之和,这个数就称为完数。

例如,6的因子为1,2,3,且6=1+2+3,因此6是完数,从键盘上输入一个正整数,判断其是否为完数。

如果是,则按照如下格式输出。

比如,输入6,则输出Yes,its factors are 1 2 3;如果输入8,则输出No#include<stdio.h>int main(){int yinzi,num,i,sum=0;scanf("%d",&num);for(yinzi=1; yinzi<num; yinzi++){if(num%yinzi==0)sum=sum+yinzi;}if(sum==num){printf("Yes,its factors are ");for(i=1; i<num; i++){if(num%i==0)printf(" %d",i);} (输出因子具体值) printf("\n");}else printf("No\n");return 0;}【设计型】5.9 素数输入两个正整数m和n,求出[m,n]区间的所有素数#include<stdio.h>int main(){int m,n,i,j,tag=1;scanf("%d%d",&m,&n);for(i=m; i<=n; i++){for(j=2; j<i; j++) {if(i%j==0){tag=0;break;}else tag=1;}if(tag)printf(" %d",i);}printf("\n");return 0;}【设计型】5.10 回文数输入一个数,判断是否为回文数,如果是,输出Yes,否则输出No #include<stdio.h>int main(){double num;scanf("%lf",&num);int min=0, max=num;while (max>0){min=min*10+(int)max%10;(将数字反过来)max=max/10;}if(num==min)printf("Yes\n");else printf("No\n");return 0;}【设计型】5.11 贪吃的猴子有一只猴子,第一天摘了若干个桃子,当即吃了一半,但还觉得不过瘾,就又多吃了一个。

第2天早上又将剩下的桃子吃掉一半,还是觉得不过瘾,就又多吃了两个。

以后每天早上都吃了前一天剩下的一半加天数个(例如,第5天吃了前一天剩下的一半加5个)。

到第n天早上再想吃的时候,就只剩下一个桃子了。

输入:天数n输出:第一天的桃子个数,输出语句为printf("The monkey got %d peachs in first day.\n",sum);Smaple:Input:5OutputThe monkey got 114 peachs in first day.提示:问题分析:总共 t0日吃掉剩余1 t0/2+1 t0-(t0/2+1)=t0/2-1 t1=t0/2-1 =>t0=(t1+1)*22 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)*2n 1 0 tn-1=1#include<stdio.h>int main(){int i,t,sum;scanf("%d",&t);sum=1;for(i=t;i>1;i--){sum=(sum+i-1)*2;?}printf("The monkey got %d peachs in first day.\n",sum);return 0;}【创新型】5.12 马戏团观众人数一个马戏团表演, n 个座位全满,全部门票收入是 120 元,现在知道,男人每人 5 元,女人每人 2 元,小孩每人 1 角。

编程,输入总人数 n ,输出满足要求的男人、女人和小孩人数的全部方案。

若 n 人无法满足条件,则输出“No output\n”。

输入:人数 n输出:男人、女人和小孩人数#include<stdio.h>int main(){int man,woman,child,total,sum,tag=0;scanf("%d",&total);for(man=0; man<=total; man++){for(woman=0; woman<=(total-man); woman++){child=total-man-woman;sum=50*man+20*woman+1*child;if(sum==1200){tag=1;printf("%d %d %d\n",man,woman,child); }}}if(tag==0)printf("No output\n");return 0;}【设计型】5.13 迭代法用迭代法求.求平方根的迭代公式为:要求前后两次求出的x的差的绝对值小于10-5。

相关主题