




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、六、编程题参考答案1编程,统计在所输入的50个实数中有多少个正数、多少个负数、多少个零。 #include "stdio.h" #define N 50 void main() float x; unsigned int s1,s2,s3,i; s1=s2=s3=0; for(i=1;i<=N;i+) scanf("%f",&x); if(x<0) s1+; else if(x=0) s2+; else s3+; printf("负数%u个,零%u个,正数%u个n",s1,s2,s3); 2. 编程,计
2、算并输出方程 X2+Y2=1989 的所有整数解。 #include "stdio.h" void main() int x,y; for(x=-45;x<=45;x+) y=-45; while(y<=45) if(x*x+y*y=1989) printf("%d*%d+%d*%d=%dn",x,x,y,y,1989); y+; 3编程,输入一个10进制正整数,然后输出它所对应的八进制、十六进制数。 #include "stdio.h" void main() unsigned int x; printf(&
3、quot;请输入一个十进制正整数:"); scanf("%u",&x); printf("%d=八进制数 %o=十六进制数%xn",x,x,x); 4编程,找出1000以内的所有完数,并输出其因子。 #include "stdio.h" void main() int i,j,s=1; for(i=1;i<=1000;i+,s=1) for(j=2;j<=i/2;j+) if(i%j=0) s+=j; / 求 i的因子和 if(s=i) printf("%d=1",i);
4、/ 如果i 是完数则输出其各因子 for(j=2;j<=i/2;j+) if(i%j=0) printf("+%d",j); printf("n"); 5. 输入一个正整数,输出它的所有质数因子。 #include "stdio.h" void main() int m,i=2; printf("请输入一个整数:"); scanf("%d",&m); while(m!=1) if(m%i=0) printf("%d ",i); m/=i; else
5、i+; printf("n"); 6. 输入20个整数,输出其中能被数组中其它元素整除的那些数组元素。 #include "stdio.h" #define N 20 void main() int aN,i,j; for(i=0;i<N;i+) scanf("%d",&ai); for(i=0;i<N;i+) for(j=0;j<N;j+) if(ai%aj=0&&i!=j) printf("%dn",ai); break; 7. 输入两个数组(数
6、组元素个数自定),输出在两个数组中都出现的元素。 #include "stdio.h" #define NA 6 #define NB 8 void main() float aNA,bNB; int i,j; for(i=0;i<NA;i+) scanf("%f",&ai); for(i=0;i<NB;i+) scanf("%f",&bi); for(i=0;i<NA;i+) for(j=0;j<NB;j+) if(ai=bj) printf("%fn",ai); brea
7、k; 8. 输入两个数组(数组元素个数自定),输出在两个数组中都不出现的元素。 #include "stdio.h" #define NA 6 #define NB 8 void main() float aNA,bNB; int i,j; for(i=0;i<NA;i+)scanf("%f",&ai); for(i=0;i<NB;i+)scanf("%f",&bi); for(i=0;i<NA;i+) for(j=0;j<NB;j+) if(ai=bj) break; if(j=N
8、B) printf("%f ",ai); printf("n"); for(i=0;i<NB;i+) for(j=0;j<NA;j+) if(bi=aj) break; if(j=NA) printf("%f ",bi); printf("n"); 9编程,将字符数组S2中的全部字符拷贝到字符数组S1中。 #include "stdio.h" void main() char s120,s2="Good morning!" int i=0; while
9、(s1i+=s2i)!='0'); printf("%sn",s1); 10给定年份year,判别该年份是否闰年(定义一个宏以判别该年份是否闰年)。 #include <stdio.h> #define f(year) year%4=0&&year%100!=0|year%400=0 void main() int y; printf("请输入年份:"); scanf("%d",&y); if(f(y) printf("%d 年为闰年n",y); el
10、se printf("%d 年不是闰年n",y); 11输入一行小写字母后,或输出原文,或将字母变成其下一字母(a变成b、b变成c、x变成y、y变成z、z变成a)输出,用条件编译方法实现以上选择。 #include <stdio.h> #define MAX 80 #define SWITCH 1 void main() char strMAX; int i=0; printf("请输入文本行:n"); scanf("%s",str); #if(SWITCH) while(stri!='0')
11、if(stri>='a'&&stri<='z') if(stri='z')stri='a' else stri+; i+; #endif printf("%sn",str); 12. 编写函数,处理n行n列维数组:将每一行的元素同除以该行上绝对值最大的元素。 #include "stdio.h" #include "math.h" void div(float* a,int n) int i,j; float x; for(i=0;
12、i<n;i+) x=*(*(a+i); for(j=1;j<n;j+) if(fabs(*(*(a+i)+j)>fabs(x) x=*(*(a+i)+j); for(j=0;j<n;j+) *(*(a+i)+j)/=x; return; void main() / 函数引用示例 float b33=1,2,3,4,5,6,7,8,9; int i,j; float* c3; for(i=0;i<3;i+) ci=bi; div(c,3); for(i=0;i<3;i+) for(j=0;j<3;j+) printf("%f ",bi
13、j); printf("n"); 13. 编写函数,求任意阶多项式 a0+a1X+a2X2+.+anXn 的值并返回多项式的值。 #include "stdio.h" float f1(float* a,float x,int n) int i; float t=1,y=0; for(i=0;i<n;i+) y+=*(a+i)*t; t*=x; return y; void main() / 函数引用示例 float b4=1,2,3,4; printf("%fn",f1(b,2,4); 14. 设计一个
14、函数,使给出一个数的原码,能得到该数的补码。 #include <stdio.h> / 假定sizeof(int)为2; unsigned int getbit(unsigned int value) /第1位为0表示数的原码, if(value>>15) return (value0x7fff)+1; /其补码即其原码;若value else return value; /右移15位后为1,表示value是负数的原码,负数 /的补码为原码按位取反(第1位不变)后加1。 void main() unsigned int y=0x800c,k; k=getbit(y);
15、printf("%xn",k); 15. 编写函数,求m行、n列的二维数组全体元素中负数的个数。 #include <stdio.h> int sum(float *a,int m,int n) int i,j; int y=0; for(i=0;i<m;i+) for(j=0;j<n;j+) if(*(*(a+i)+j)<0) y+; return y; void main() / 函数引用示例 float b23=-1,2,-3,4,-5,-6; int i; float* c2; for(i=0;i<2;i+) ci=b
16、i; printf("%dn",sum(c,2,3); 16. 编写函数,返回在一个整数组中出现次数最多的数及其出现次数。 #include <stdio.h> void fun(float *a,int n,int *k,float *x) int i,j,y; *k=0; for(i=0;i<n;i+) y=0; for(j=0;j<n;j+) if(*(a+i)=*(a+j) y+; if(y>*k) *k=y; *x=*(a+i); return; void main() / 函数引用示例 float c10=0,4,2,4,3,2,4
17、,-3,1.5,7.6,t; int m; fun(c,10,&m,&t); / 若说明float *t; int *m; printf("元素%f出现次数为%dn",t,m); / 引用为 fun(c,10,m,t) 将 / 产生悬挂指针的错误,即t、m不只指向确定的存储单元。 17编一个程序,打入月份号,输出该月的英文月名,要求用指针数组处理。 #include <stdio.h> void main() char *month_name12="January","February",&quo
18、t;March","April", "May", "June","July","August","September","October", "Novenber","December" int n; printf("请输入月份号:"); scanf("%d",&n); if(n<1|n>12) printf("月份号输入错误!n"
19、;); else printf("%d月的英文表示是%sn",n,month_namen-1); 18编写递归函数,将输入的以“?”结束的字符串按与输入相反的顺序输出。 #include <stdio.h> void pline() char ch; if(ch=getchar()!='?') pline(); putchar(ch); return; void main() / 函数引用示例 pline(); printf("n"); 19. 编写函数,在n个元素的一维数组中,统计比相邻元素大的数组元
20、素个数并将统计数返回(不考虑a0和an-1),要求以指针变量而不是数组名作参数。 #include <stdio.h> int num(float *x,int n) int i,k=0; for(i=1;i<n-1;i+) if(*(x+i)>*(x+i-1)&&*(x+i)>*(x+i+1) k+; return k; void main() / 函数引用示例 float a10=1,3,4,2,6,7,12,5,9,8; printf("%dn",num(a,10); 20. 编写函数,在n个元素的一维数组中,
21、找出最大值、最小值并传送到调用函数。 #include <stdio.h> void num(float *b,int n,float *max,float *min) *max=*b; *min=*b; for(int i=1;i<n;i+) if(*(b+i)>*max) *max=*(b+i); if(*(b+i)<*min) *min=*(b+i); return; void main() / 函数引用示例 float a10=1,3,4,2,6,7,12,5,9,8,x,y; num(a,10,&x,&y); printf("最
22、大值为%f,最小值为%f。n",x,y); 21. 编写一个函数,统计m行n列二维数组中有多少个正数、多少个负数,多少个零,并返回统计结果。 #include <stdio.h> void sub(float* a,int m,int n,int *fs,int *lin,int *zs) int i,j; *fs=*lin=*zs=0; for(i=0;i<m;i+) for(j=0;j<n;j+) if(*(*(a+i)+j)<0) (*fs)+; else if(*(*(a+i)+j)=0) (*lin)+; else (*zs)+; return
23、; void main() / 函数引用示例 float b53=-1,5,2,3,0,-2,0,-3,5, 4,7,-8,3,4,5,*c5; int i,k1,k2,k3; for(i=0;i<5;i+) ci=bi; sub(c,5,3,&k1,&k2,&k3); printf("负数%d个,零%d个,正数%d个。n",k1,k2,k3); 22. 编写函数,在给定的一行以'.'结束的字符中,找出最长的单词并输出。 #include <stdio.h> void find(char *str) ch
24、ar *p1,*p2,*p3; int k1=0,k2=0; / k1为最长串的长度,初值为0。 p1=p2=p3=str; / p3指向最长串首字符,p1指向当前处理串首字符, while(*p2!='.') / p2为移动指针,*p2为空格表示查找到单词尾部。 if(*p2!=' ') k2+; p2+; else if(k2>k1) p3=p1; p1=+p2; k1=k2; k2=0; else k2=0; p1=+p2; for(k2=0;k2<=k1;k2+) printf("%c",*(p3+k2); printf(
25、"n"); return; void main() / 函数引用示例 char a40; int i=0; while(ai+=getchar()!='.'); find(a); 23. 编写函数print,打印一个学生的成绩数组,该数组中有若干个学生的数据记录,每个记录包括num,name,score3。 #include <stdio.h> struct student char num7,name9;int score3; ; / 尾部分号不得遗漏 void print(struct student* s,int n) int
26、i; / 运算符'*'、'&'的优先级均低于运算符'.' for(i=0;i<n;i+) printf("%s %s %4d%4d%4dn",(*(s+i).num,(*(s+i).name, (*(s+i).score0,(*(s+i).score1,(*(s+i).score2); return; void main() struct student t4; int i; for(i=0;i<4;i+) scanf("%s%s%d%d%d",&ti.num,&ti.n
27、ame,&ti.score0, &ti.score1,&ti.score2); print(t,4); 24. 把文本文件d1.dat复制到文本文件d2.dat中,要求仅复制d1.dat中的英文字符。 #include <stdio.h> void main() FILE *fpd1,*fpd2; char ch; fpd1=fopen("d1.dat","r"); fpd2=fopen("d2.dat","w"); while(fscanf(fpd1,"%c"
28、;,&ch)!=EOF) if(ch>='A'&&ch<='Z'|ch>='a'&&ch<='z') fprintf(fpd2,"%c",ch); fclose(fpd1); fclose(fpd2); 25. 编程,把文本文件d1.dat复制到d2.dat(其中空格字符不复制)。 #include <stdio.h> void main() FILE *fpd1,*fpd2; char ch; fpd1=fopen(&qu
29、ot;d1.dat","r"); fpd2=fopen("d2.dat","w"); while(fscanf(fpd1,"%c",&ch)!=EOF) if(ch!=' ') fprintf(fpd2,"%c",ch); fclose(fpd1); fclose(fpd2); 26. 编程,把文本文件d1.dat复制到d2.dat(其中大写英文字母要转换为小写字母)。 #include <stdio.h> void main() FIL
30、E *fpd1,*fpd2; char ch; fpd1=fopen("d1.dat","r"); fpd2=fopen("d2.dat","w"); while(fscanf(fpd1,"%c",&ch)!=EOF) if(ch>='A'&&ch<='Z') ch=ch+32; fprintf(fpd2,"%c",ch); fclose(fpd1); fclose(fpd2); 27. 把文本文
31、件d1.dat复制到文本文件d2.dat中,要求仅复制d1.dat中除英文字符和数字以外的其它内容。 #include <stdio.h> void main() FILE *fpd1,*fpd2; char ch; fpd1=fopen("d1.dat","r"); fpd2=fopen("d2.dat","w"); while(fscanf(fpd1,"%c",&ch)!=EOF) if(!(ch>='A'&&ch<='
32、Z'|ch>='a'&&ch<='z'|ch>='0'&&ch<='9') fprintf(fpd2,"%c",ch); fclose(fpd1); fclose(fpd2); 28. 求出1至100之间的素数(只能被1和自身整除的数)并顺序写入文件su.dat。 #include <stdio.h> #include <math.h> void main() FILE *fp; int i,j,k=2; fp=
33、fopen("su.dat","w"); fprintf(fp,"%4d%4d",2,3); for(i=5;i<100;i=i+2) for(j=3;j<=sqrt(i);j=j+2) if(i%j=0) break; if(j>sqrt(i) fprintf(fp,"%4d",i); k+; if(k%10=0) fprintf(fp,"n"); fclose(fp); 29磁盘文件a1和a2,各自存放一个已按字母顺序排好的字符串,编程合并二个文件到a3文件中,
34、合并后仍保持字母顺序。 #include <stdio.h> #include <math.h> void main() FILE *fp1,*fp2,*fp3; int i,j,k; char c1,c2; fp1=fopen("a1","r"); fp2=fopen("a2","r"); / 首先从文件a1、a2中各读入一个字符分别送入变量c1、c2,下面将作 / 循环比较,直到读到文件尾标志为止。 fp3=fopen("a3","w"); c1=
35、fgetc(fp1); c2=fgetc(fp2); do if(c1<c2) fputc(c1,fp3);c1=fgetc(fp1); else fputc(c2,fp3); c2=fgetc(fp2); while(!feof(fp1)&&!feof(fp2); / 若a1先读到文件尾,则将c2写入a3,再将a2中其它字符读入后写入a3;. if(feof(fp1) do fputc(c2,fp3); c2=fgetc(fp2); while(!feof(fp2) ; else do fputc(c1,fp3); c1=fgetc(fp1); while(!feof(
36、fp1) ; fclose(fp1); fclose(fp2); fclose(fp3); 30顺序文件C.DAT每个记录包含学号(8位字符)和成绩(三位整数)两个数据项。从文件读入学生成绩,将大于或等于60分的学生成绩再形成一个新的文件SCORE60.DAT保存在A盘上,并显示出学生总人数、平均成绩和及格人数。 #include <stdio.h> #include <math.h> void main() FILE *fp1,*fp2; char s9; int x,zrs=0,pjcj=0,jgrs=0; fp1=fopen("c.dat&q
37、uot;,"r"); fp2=fopen("a:score60.dat","w"); fscanf(fp1,"%s%d",s,&x); do zrs+; pjcj+=x; if(x>=60) jgrs+; fprintf(fp2,"%s %dn",s,x); fscanf(fp1,"%s%d",s,&x); while(!feof(fp1); printf("总人数:%d 平均成绩:%d 及格人数:%dn",zrs,pjcj/zrs,
38、jgrs); fclose(fp1); fclose(fp2);31程序清单:typedef int datatype;typedef struct nodedatatype data;struct node *next;linklist;INVERT(linklist *head)linklisk *p,*q; p=head->next; if(p!=NULL) head->next=NULL; doq=p->next; p->next=head->next; head->next=p; p=q;while(p!=NULL);32程序清单:PURGE(li
39、nklist *head)linklist *p,*q; q=head->next; if(q=NULL)return;p=q->next;while(p!=NULL)if(p->data=q->data)q=p->next; free(p);p=q->next;elseq=p;p=p->next;33、程序清单:#include <stdio.h>main()static char x=”computer”; char *p; for(p=x;p<x+7;p+=2)putchar(*p);printf(“n”);34、#includ
40、e <stdio.h>#include <string.h>main()int m;char str80,str280;printf(“input a string:n”);gets(str2);printf(“intput m:n);scanf(“%d”,&m);if(strlen(str2)<m) printf(“err input!n”);elsecopystr(str1,str2,m);printf(“rsult is :%sn”,str1);copystr(char *p1,char *p2,int m)int n=0;while(n<m-
41、1)p2+; n+;while(*p2!=0)*p1=*p2;p1+=; p2+;*p1=0;35、程序清单:float search(float (pointer)4,int n)float *pt;pt=*(pointer+n);return(pt);36、Main()int score4=60,76,80,90,45,86,57,90,58,95,80,71,78,50,60,85; int (*p)4,j,k,flag;p=score;for(j=0,j<4;j+) if(*(*(p+j)+k)<60)flag=1; if(flag=1) printf(“NO.%dis f
42、ail,svoreare:n”,j);for(k=0,;k<4;k+) printf(“%5d”, *(*(p+j)+k); printf(“n”);37、程序清单:main()int b16,x,k,r,I;printf(“enter a integer :n”):scanf(“%d”,&x);printf(%6ds binary number is:n”,x);k=-1;dor=x%2;k+;*(b+k;x/=2;while(x!=0for(I=k;I>=0;I-)printf(“%d”,*(b+i)printf(“n”);、float p(int n,int x)fl
43、aot t,t1,t2;if(n=0)return(1);else if(n=1) return(x);elset1=(2*n-1)*x*(p(n-1),x); t2=(n-1)*p(n-2),x);t=(t1-t2)/n);return(t);39、main()int a55,I,j,k=0,m,n;m=n/2+1;for(I=0,I<m;I+) for(j=I;j<n-I;j+) k+;aIj=k; for(j=I+1;j,n-I;j+) k+;an-j-1=k; for(j=n-I-2;j>=I;j-) k+;an-I-1j=k; for(j=n-2-I;j>=I
44、+1;j-)k+;aIj;for(I=0;I<n;I+) for(j=0;j<n;j+)printf(“%5d”,aIj);printf(“n”);40、#include <stdio.h>main()int m16,n,I,t,count=0;long a,k;printf(“result is:n”);for(n=10;n<200;n+)k=0;t=1;a=n*n;for(I=1;a!=0;I+)mI=a%10;a/=10;for(;I>1;I-)k+=mI-1*t;t=t*10;if(k=n*n)printf(“%2d:%10d%10dn”,+coun
45、t,n,N*n);41、void convert(char *a,int n)int I;if(I=n/10)!=0) convert(a+1,i);*a=n%10+0;42、#include <stdio.h> main()FILE*fp;char str100,fikename10;int I=0;if(fp=fopen(“upper.txt”,”w”)=NULL)printf(“can not open filen”);exit(0);printf(“enter a string:n”);gets(str);while(strI!=!) if(strI>=a&&
46、amp;strI<=z) strI=strI-32;fputc(strI,fp);I+; fclose(fp);43、#include “stdio.h” FILE *fp; main()int p=0,n=0,z=0,temp; fp=fopen(“number.dat”,”r”); if(fp=NULL) printf(“file not foundn”); elsewhile(!feof(fp) fscanf(fp,”%d”,&temp); if(temp>0) p+; else if(temp<0) n+;else z+;fclose(fp);printf(“
47、posive:%3d,negtive:%3d,zero:%3dn:,p,n,z);44、main() unsigned rightrot(unsigned a,int n) unsigned int m,b;int n;printf(“enter mand n:”);scanf(%x,%d”,&m,&n);printf(“m=%x,n=%dn”,m,n);b=rightrot(m,n);printf(“b=%xn”,b);unsigned rightrot(unsigned a,int n)int rb;while(nà0)rb=(a&1)<<(1
48、6-1);a=a>>1;a=a|rb;return a;45、解:PX(X,N)=X-X2+X3-X4+(-1)N-1XN =X*(1- X-X2+X3-X4+(-1)N-1XN-1=X*(1-PX(X,N-1)程序清单:double px(double x,int n)if(n=1) return x;else return(x*(1-px(x,n-1);46、程序清单:double opwer1(double x,int n)if(n=0) return 1;else return(x*power1(x,n-1);47、Printfn(int n)if(n=0&&
49、;n<=9) printf(“%d”,n);else printf(“%d”,x%10); printn(x/10); 48、程序清单:t(int n)int m; printf(“%d”,x%10); m=x/10;if(m>0) r(m);49、程序清单:int ack(int m,int n)if(m=0) return (n+1);else if(n=0)return(ack(m-1,1);else return(ack(m-1,ack(m,n-1);50、Void intobin(int x)if(x/2>0) intobin(x/2); printf(“%d”,x
50、%2);51、Void intobin(int x)if(x/>0) intobin(x/); printf(“%d”,x%);52、Void intobin(int x) if(x/16>0) intobin(x/16); printf(“%c”,(x%16>=9)?x%16+55:x%16+48);53、Main()int x; printf(“enter a number:n”); scanf(“%d”,&x); if(x!=0)if(x>0) x=x%2; if(x) printf(“this number is a plus odd numbern”); else printf(“this number is a plus even numbern”); else x=x%2; if(x) printf(“this number is a plus odd numbern”); else printf(“
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年快时尚行业商业模式创新与转型升级报告
- 2025年科技与互联网行业区块链在供应链金融中的应用与挑战报告
- 2025年绿色金融债券市场发行与投资风险控制策略报告
- 人事办公考试题及答案
- 资源维护激励机制设计-洞察及研究
- 活动策划合同补充协议
- 民间借贷续签合同范本
- 物流仓储退件合同范本
- 车辆质押合同借款协议
- 物料设备租借合同范本
- TSG-T7001-2023电梯监督检验和定期检验规则宣贯解读
- 横河涡街流量计DY说明书
- 隧道消防维护维修及专项工程技术文件
- 阿甘正传全部台词中英对照
- 火电厂工作原理课件
- 重金属在土壤 植物体系中的迁移及其机制课件
- 抢救车管理制度 课件
- 跌倒坠床不良事件鱼骨图分析
- 供应商分级管理制度管理办法
- 招议标管理办法
- 小儿急性上呼吸道感染的护理查房ppt
评论
0/150
提交评论