南京邮电大学C语言程序设计网站上机习题参考答案_第1页
南京邮电大学C语言程序设计网站上机习题参考答案_第2页
南京邮电大学C语言程序设计网站上机习题参考答案_第3页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

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

文档简介

网站上机程序参考源代码1:sizeof测试字节数#include<stdio.h>intmain(){printf("sizeof(char)=%d\n",sizeof(char));printf("sizeof(int)=%d\n",sizeof(int));printf("sizeof(short)=%d\n",sizeof(short));printf("sizeof(long)=%d\n",sizeof(long));printf("sizeof(unsignedint)=%d\n",sizeof(unsignedint));printf("sizeof(float)=%d\n",sizeof(float));printf("sizeof(double)=%d\n",sizeof(double));return0;}2:#include<stdio.h>intmain(){inta=20;floatb;doublec;b=12.345f;scanf("%lf",&c);printf("a=%d\n",a);printf("b=%f\n",b);printf("c=%f\n",c);return0;}3:用if语句求解分段函数#include<stdio.h>intmain(){doublex,y;scanf("%lf",&x);if(x<20)y=x+100;elseif(x<=100)elsey=x-100;printf("x=%f,y=%f\n",x,y);return0;}4#include<stdio.h>intmain(){intyear,month,day;scanf("%d%d",&year,&month);switch(month){case1:case3:case5:case7:case8:case10:case12:day=31;case4:case6:case9:case11:day=30;case2: day=28;if(year%4==0&&year%100!=0||year%400==0)day=29;break;default:printf("errormonth\n");}53位数字的质数#include<stdio.h>#include<math.h>intmain(){intm,i,k,prime,count=0;for(m=101;m<999;m=m+2){k=(int)sqrt(m);prime=1;for(i=2;prime&&i<=k;i++)if(m%i==0)prime=0;if(prime){printf("%6d",m);count++;if(count%5==0)printf("\n");}}printf("\n");return0;}6#include<stdio.h>#include<math.h>intmain(){doublex,term=1,i=1,sum=0;intsign=1;scanf("%lf",&x);do{term=term*x/i;sum+=sign*term;sign=-sign;i++;}while(fabs(term)>=1e-5);printf("sum=%.2f\n",sum);return0;}7#include<stdio.h>intmain(){inti,a[20],max,min,sum=0,count=0;for(i=0;i<20;i++)scanf("%d",&a[i]);max=min=a[0];for(i=0;i<20;i++)if(a[i]>max)max=a[i];elseif(a[i]<min)min=a[i];for(i=0;i<20;i++)if(a[i]!=max&&a[i]!=min){sum+=a[i];count++;}printf("count=%d,average=%f\n",count,sum*1.0/count);return0;}8:用数组实现Fibonacci#include<stdio.h>intmain(){intn,f[40],i;do{scanf("%d",&n);}while(n<=0||n>40);f[0]=f[1]=1;for(i=2;i<n;i++)f[i]=f[i-2]+f[i-1];for(i=0;i<n;i++){printf("%12d",f[i]);if((i+1)%6==0)printf("\n");}printf("\n");return0;}9#include<stdio.h>intmain(){inta[20];inti=0,j,x,total=0,s=0;do{scanf("%d",&a[i++]);}while(a[i-1]);s=total=i;scanf("%d",&x);printf("Beforedelete,elementsare:\n");for(i=0;i<total;i++)printf("%5d",a[i]);printf("\n");for(i=0;i<total;i++){while(i<total&&a[i]!=x)if(i==total) break;for(j=i;j<total-1;j++)a[j]=a[j+1];i--;total--;}if(total==s)printf("doesnotexist,nooperating!\n");else{printf("Afterdelete,elementsare:\n");for(i=0;i<total;i++)printf("%5d",a[i]);printf("\n");}return0;}编程题10#include<stdio.h>#include<stdlib.h>voidcreate(inta[],intn);voidprint(inta[],intn); //intmain(){intn,*array;scanf("%d",&n); //读入整数n,再调用calloc函数产生大小为n的数组array=(int*)calloc(n,sizeof(int));create(array,n); //调用create函数产生n个元print(array,n); //调用free(array);return0;}voidcreate(inta[],intn){inti;for(i=0;i<n;i++) //i控制将要产生的其它n-1个元素的下标{a[i]=i+1;}}voidprint(inta[],intn){inti;for(i=0;i<n;i++){ printf("%d,",a[i]); //输出元素}printf("\n");} 编程题#include<stdio.h>#include<stdlib.h>voidFind(int*a,intn,int*max,int*maxPos,int*min,int*minPos);intmain(){intarray[10]={23,45,90,-9,43,90,4,2,-9};intmax,min,maxPos=0,minPos=0;Find(array,10,&max,&maxPos,&min,&minPos);printf("max=%d,maxPos=%d,min=%d,minPos=%d\n",max,maxPos,min,minPos);return0;}voidFind(int*a,intn,int*max,int*maxPos,int*min,int*minPos){inti;*max=*min=a[0];for(i=1;i<n;i++)if(a[i]>*max){*max=a[i];*maxPos=i;}elseif(a[i]<*min){*min=a[i];*minPos=i;}}12:八进制转换为二进制#include<stdio.h>intOctToBin(intn,int*p){inti,r,k=0;while(n){ r=n%8;for(i=1;i<=3;i++) p[k++]=r%2;r=r/2;}n=n/8;}returnk;}intmain(){inti,n,array[30],k;scanf("%o",&n);k=OctToBin(n,array);while(array[k-1]==0)k--;for(i=k-1;i>=0;i--)printf("%d",array[i]);printf("\n");return0;}13:最大公约数。#include<stdio.h>intgcd(intm,int{intr;r=m%n;if(!r)returnn;else}

returngcd(n,r);intmain(){intm,n;do{ scanf("%d%d",&m,&n);}while(m<=0||n<=0);printf("gcd=%d\n",gcd(m,n));return0;}14:#include<stdio.h>#include<math.h>#defineS(a,b,c)((a)+(b)+(c))/2#defineAREA(s,a,b,c)sqrt((s)*((s)-(a))*((s)-(b))*((s)-(c)))intmain(){doublea,b,c,s,area;scanf("%lf%lf%lf",&a,&b,&c);if(a<=0||b<=0||c<=0||a+b<=c||a+c<=b||b+c<=a)printf("Error!Pleaseinputagain.\n");else{s=S(a,b,c);area=AREA(s,a,b,c);printf("Area=%.3lf\n",area);}return0;}15:。#include<stdio.h>#defineLEAP_YEAR(y)(y)%400==0||(y)%4==0&&(y)%100!=0intmain(){intyear;scanf("%d",&year);if(year>=10000||year<=999)printf("Inputerror!\n");else

if(LEAP_YEAR(year))printf("%disaleapyear!\n",year);elsereturn0;}

printf("%disnotaleapyear!\n",year);16#include<stdio.h>typedefstructStudent{intnum;charname[20];intscore;}STU;voidinput(STU*t,intn){inti;for(i=0;i<n;i++){scanf("%d",&t[i].num);getchar();scanf("%s",t[i].name);scanf("%d",&t[i].score);}}STU*average(STU*t,intn,double*ave){intSTU*high;for(i=0;i<n;i++)sum+=t[i].score;high=t;for(i=1;i<n;i++)if(t[i].score>high->score)high=t+i;*ave=sum*1.0/n;returnhigh;}intmain(){STUteam[3],*high=NULL;doubleave;input(team,3);high=average(team,3,&ave);printf("Theaveragescore=%.2f\n",ave);printf("Thestudentwhohasthehighestscoreis:\n");printf("%d\t%s\t%d\n",high->num,high->name,high->score);return0;}编程题17#include<stdio.h>enumSeasons{Spring,Summer,Autumn,Winter};structDate{intyear,month,day;};intmain(){structDated;enumSeasonss;scanf("%d%d%d",&d.year,&d.month,&d.day);if(d.month>=3&&d.month<=5)s=Spring;elseif(d.month>=6&&d.month<=8)s=Summer;elseif(d.month>=9&&d.month<=11)s=Autumn;elseif(d.month==12||d.month==1||d.month==2)s=Winter;switch(s){caseSpring:printf("NowitisSpring\n");break;caseSummer:printf("NowitisSummer\n");caseAutumn:printf("NowitisAutumn\n");break;caseWinter:printf("NowitisWinter\n");break;}return0;}18#include<stdio.h>intinput(char*s){inti=0;charc;do{c=getchar();if(c>='0'&&c<='9'||c>='A'&&c<='F'||c>='a'&&c<='f')s[i++]=c;elsereturn0;}while(i<4);s[i]='\0';return1;}intchange(char*s){intn=0,i=0;while(s[i]){if(s[i]>='0'&&s[i]<='9')n=n*16+(s[i]-48);elseif(s[i]>='A'&&s[i]<='F')n=n*16+(s[i]-55);elseif(s[i]>='a'&&s[i]<='f')n=n*16+(s[i]-87);i++;}returnn;}intmain(){chars[5]; //定义字符数组if(input(s)) //printf("Thedecdatais:%d\n",change(s));else //printf("Originaldataerror\n");return0;}19#include<stdio.h>#include<string.h>voidreverse(char*s){char*p=s,*q,t;intlen=strlen(s);q=p+len-1;while(p<q){t=*p;*p=*q;*q=t;p++;q--;}}intmain(){chars[100];gets(s);reverse(s);puts(s);return0;}20#include<stdio.h>intchange(char*source,char*des){inti=0;while(*source){if(*source>='0'&&*source<='9')des[i++]=*source;source++;}des[i]='\0';returni;}doublecalcu(char*s){doubleresult=0;while(*s){result=result*10+(*s-48);s++;}returnresult;}intmain(){charstr[50],strdes[50];gets(str);if(change(str,strdes))printf("%.4f\n",calcu(strdes));elseprintf("thedigitalstringisempty!\n");return0;21:打印杨辉三角形#include<stdio.h>intmain(){inty[10][10]={0},i,j,n;scanf("%d",&n);for(i=1;i<=n;i++)y[i][1]=y[i][i]=1;for(i=3;i<=n;i++)for(j=2;j<n;j++)y[i][j]=y[i-1][j-1]+y[i-1][j];for(i=1;i<=n;i++){for(j=1;j<=i;j++)printf("%5d",y[i][j]);printf("\n");}return

温馨提示

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

评论

0/150

提交评论