




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、传播优秀word版文档 ,希望对您有帮助,可双击去除!c上机题1. 设 y(n) = 1 n<= 1时; y(n) = -y(n-2)+2*y(n-1) n>1时。编一c程序,它能对读入的任意n(n>=0且n<50),能计算并输出y(n)的值。(注:程序命名为e1_2.exe)#include "stdio.h"int y(n) int n; if (n<=1) return 1; else return
2、0; (-y(n-2)+2*y(n-1);void main() int n; printf("please input the n :n"); scanf("%d",&n); printf("y(%d)=%d n",n,y(n);2编一c程序,它能读入一个字符串(串长<100,串中可能有空格符),计算并输出该字符串中十进制数字的个数。(注:程序命名为e1_3.exe)#include "stdio.h"#include "string.h&q
3、uot;#define max 100void main()char amax;int n=0,i,j;printf("please input the char :n"); gets(a); i=strlen(a); if (i>=100 | i<=0) printf("sorry! there is more than or less than one hundred number n"); else if (i<100 && i
4、>0) for(j=0;j<i;j+) if (aj>='0' && aj<='9') n+; printf("the length is :%d n",n);第三题编一c程序,它能读入一正整数n,(n<10),并输出如下图形: &
5、#160; 1 2 2 2 3 3 3 3 3 .
6、; . n n . . . . . nn (共2n-1个n) .
7、0; . 3 3 3 3 3 2 2 2 1 (可执行文件名为e2_1.exe)#incl
8、ude "stdio.h"void print(int a,int printnum,int charnum ,char printchar) int i,j; for(i=0;i<charnum;i+) printf("%c ",printchar); for(j=i;j<=i+printnum-1;j+) printf("%d ",a); printf("n");void main()&
9、#160; int n,printnum,i,charnum; char printchar=' ' printf("please input the n:n"); scanf("%d",&n); if (n>=10 | n<=0) printf("please input n again (n<10 and n>0):n"); scanf("%d",&n); /
10、*i为打印的数字printnum为打印数字的个数printchar为打印的空格charnum为打印的空格个数 */ for(i=1,printnum=2*i-1,charnum=n-i;i<=n;i+,printnum+=2,charnum-) print(i,printnum,charnum,printchar); for(i-=2,printnum-=4,charnum=1;i>=1;i-,printnum-=2,charnum+) print(i,printnum,charnum,pri
11、ntchar);4. 编一c程序,它能读入矩阵a的行数l,列数m,矩阵b的列数n,矩阵b的行数是m。l,m,n值都小于20), 以及按行读入矩阵a的l*m个元素(整数)及矩阵b的m*n个元素(整数),计算并输出a与b的矩阵乘积(按行,列输出)。(输入时,相邻的两个整数用空格隔开)。(可执行文件名为e2_2.exe)#include "stdio.h"#define max 20void main() int l,m,n,i,k,j,o,amaxmax,bmaxmax,cmaxmax,tmp=0; printf("please input t
12、he l :n"); scanf("%d",&l); printf("please input the m :n"); scanf("%d",&m); printf("please input the n :n"); scanf("%d",&n); if (l>=20 |l<=0) printf("please input l again (0
13、<l<20):n"); scanf("%d",&l); if (m>=20 |m<=0) printf("please input m again (0<m<20):n"); scanf("%d",&m); if (n>=20 |n<=0) printf("please input n again (0<n
14、<20):n"); scanf("%d",&n); printf("please input the number in a%d%d:n",l,m); for(i=0;i<l;i+) for(j=0;j<m;j+) scanf("%d",&aij); printf("please input the number in b%d%d:n&quo
15、t;,m,n); for(i=0;i<m;i+) for(j=0;j<n;j+) scanf("%d",&bij); for(i=0;i<l;i+) for(k=0;k<n;k+) tmp=0; for(j=0;j<m;j+)
16、0; tmp+=aij*bjk; cik=tmp; printf("the result is:n"); for(o=0;o<i;o+) for(j
17、=0;j<k;j+) printf("%d ",coj); printf("n"); 5.编一c程序,它能读入n(n<200)个整数(以-9999为结束标记,-9999不算在内,相邻的两个整数用空格隔开),找出第1到第n-1个数中第一个与第n个数相等的那个数,并输出该数读入时的序号(序号从1开始记)。(可执行文件名为e2_3.exe)#include &q
18、uot;stdio.h"#define max 200void main() int i,j,n,flag=0,tmp,amax; printf("please input the number :n"); for(i=0;i<max;i+) scanf("%d",&ai); if (ai=-9999) break; n=-i; tmp=ai; for(i=0;i<
19、;n && flag=0;i+) if (tmp=ai) j=i; flag=1; break; if (flag=0) printf("sorry! there is not found!n"); else
20、160; if(flag=1) printf("the aquality number place is :n"); printf("%d",+j); printf("n");6.编
21、一c程序,它能读入一正整数n(n<40),并输出如下图形: a a a . a a a a . a . .
22、60; a a a . a 共n行,每行n个a,下一行比上一行右移一列.(注:可执行文件名为e3_1.exe)#include "stdio.h"#define max 40void main() int n,i,m,j; char printchar=' ',printnum='a' printf("please input the n:n"); scanf("%d&q
23、uot;,&n); if (n>=40 | n<=0) printf("please input the n again(0<n<%d) :n",max); scanf("%d",&n); for(i=0;i<n;i+) for(j=0;j<=i;j+) printf("%c"
24、;,printchar); for(m=0;m<n;m+) printf("%c",printnum); printf("n"); 7.编一c程序,它能读入一个正整数,并输出该正整数的17进制形式,依次用a、b、c、d、e、f、g表示10、11、12、13、14、15、16。(注:可执行文件名为e3_2.exe)#include "stdio.h"void main() int n,i=0,j,b17
25、; char a17="0123456789abcdefg" printf("please input the n :n"); scanf("%d",&n); do j=n%17; bi+=j; n=n/17; while(n!=0); for(i-;i>=0;i-) j=bi;
26、printf("%c",aj); printf("n");第八题编一c程序,它能读入两个整数m与n,计算并输出m与n的绝对值的最大公约数及最小公倍数。(注:可执行文件名为e3_3.exe)分析:求最大公约数的算法思想:(最小公倍数=两个整数之积/最大公约数) (1) 对于已知两数m,n,使得m>n; (2) m除以n得余数r; (3) 若r=0,则n为求得的最大公约数,算法结束;否则执行(4); (4) mn,nr,再重复执行(2)。#include "stdio.h"void main()
27、; int nm,r,n,m,t; printf("please input two numbers:n"); scanf("%d %d",&m,&n); if (m<0) m*=-1; if (n<0) n*=-1; nm=n*m; if (m
28、<n) t=n; n=m; m=t; r=m%n; while (r!=0) m=n; n=r; r=m%n; printf("最大公约数:%dn",n); printf("最小公倍数:%dn",nm/n); 9.编一c程序,它能读入一个13进制数(用字符串表示,用a、b、c分别表示10、11和12)
29、,输出该数的值(按十进制数输出)。如输入为3b时,输出为50。(注:可执行文件名为e4_1.exe)#include "stdio.h"#include "stdlib.h"void main(void)char str64,*p;unsigned long x;printf("input the number:n");gets(str);x=strtoul(str,&p,13);printf("the number is %ldn",x);10.任何进制转换成十进制#include &quo
30、t;stdio.h"#include "stdlib.h"void main(void)char str64,*p;unsigned long x;printf("input the number:n");gets(str);x=strtoul(str,&p,13); /*只是这里该是几进制就改为几 */printf("the number is %ldn",x);11.题编一c程序,它能依次读入三组d1、r1、d2、r2、d3、r3共18个非负整数(其中0<=r1<d1,0<=r2&
31、lt;d2,0<=r3<d3),对每组6个非负整数依次判断是否有正整数n,满足n%d1=r1且n%d2=r2且n%d3=r3,若有,则输出其中最小者;否则,输出no。(输入整数时,相邻的两个用空格隔开)。(注:可执行文件名为e4_2.exe)#include "stdio.h"void main() int l,i,n,d1,r1,d2,r2,d3,r3; for(i=0;i<=2;i+) l=1; n=1; printf("please input the
32、number (0<=r1=<d1 0<=r2=<d2 0<=r3=<d3):n"); /*别犯低级错误!scanf(“%dn”,&n); 千万别那样写 */ scanf("%d %d %d %d %d %d",&d1,&r1,&d2,&r2,&d3,&r3); while(l!=0)&&(n<=d1*d2*d3) ) &
33、#160; if (n%d1=r1) && (n%d2=r2) && (n%d3=r3) printf("%dn",n); l=0; else n+; if (l!=0) printf(&quo
34、t;non"); 12.编一c程序,它能读入10个用空格隔开的整数n1,n2,n10,对于i=1,2,10,执行:若ni是某个整数的5次方,则输出yes,否则输出no。#include "stdio.h"void main() int a10,i,j,m,n=10; printf("please enter 10 numbers:n"); for (i=0;i<n;i+) scanf("%d",&ai);
35、160; for (i=0;i<10;i+) if (ai>0) if (ai=1) printf("%d yes",ai); else
36、160; m=0; for (j=0;j<=ai/5;j+) if (j*j*j*j*j=ai) m=1; break;
37、60; if (m=1) printf("%d yes",ai); if (m=0) printf("%d no",ai); else
38、0; if (ai<0) n=0; for (j=0;j>=ai;j-) if (j*j*j*j*j=ai) n=1; break;
39、160; if (n=1) printf("%d yes",ai); if (n=0) printf(&quo
40、t;%d no",ai); else if (ai=0) printf("%d yes ",ai); printf("
41、n"); 13.编一c程序,它能读如若干浮点数f1、f2、.fn(以-9999.0为结束标记,-9999.0不算在内)并输出在f2、f3、.fn这n-1个数中大于f1的数的个数、等于f1的数的个数和小于f1的数的个数。(注:可执行文件名为e4_3.exe)include "math.h"#include "stdio.h"void main() float f100,f1; int n=0,i,i1=0,i2=0,i3=0; &
42、#160; printf("please enter float number :n"); scanf("%f",&f1); f0=f1; while (fn!=-9999.0) scanf("%f",&f+n); for (i=1;i<=n-1;i+) if (
43、fi>f1) i1+; else if (fi<f1) i3+; else i2+; printf(">f1:%dn",i1); printf("=f1:%dn",i2);
44、 printf("<f1:%dn",i3); 14.输入一个整数x和一个正整数n,求x(x-1)(x-2)(x-3).(x-n+1)的值并输出.好象上次还考过呢.用递归,这里只给出算法,没有输入输出,没有溢出处理int get(int x,int n) if(n = 0) return 1; /最后一步,相当于x*1 else return (x-n+1) * get(x,n-1); void main()
45、160; int r; r = get(-5,3);15.编一c程序,它能读入若干个非零浮点数(相邻的两个数用空格隔开,以0.0为输入结束标记,0.0不算在内),计算并输出这些数的平均值。(注:可执行文件名为e5_1.exe)#include "math.h"#include "stdio.h"void main() float f,s=0.0; int n=0;
46、160; printf("please enter float number:n"); scanf("%f",&f); if (fabs(f-0.0)<1e-4) printf("no number!n"); e
47、lse while (fabs(f-0.0)>1e-4) n+; s+=f; scanf("%f",&f); if (n!=0)
48、 printf("%d number of average is:%fn",n,s/n); 16.编一c程序,它能反复读入正整数(相邻的用空格隔开),并判断它是否为素数(质数),若是,则输出“yes”,否则,输出“no”,直到读入1时,程序终止执行。(注:可执行文件名为e5_2.exe)#include "stdio.h"#define max 10000void test (int a) int j,testdiv=2; if (a
49、>2) for(j=0;testdiv<=a/2 && j=0;testdiv+) if (a%testdiv=0) j=1; break; if (j=1 | a<=1)
50、 printf("no "); else printf("yes ");void main() int n,i,amax; printf("please input the number :n"); for(i=0;i<max;i+) scanf("%d",&ai); if (ai=1)
51、60; break; n=i; printf("the result is :n"); for(i=0;i<n;i+) test(ai); printf("n");17.编一c程序,它能读入21个整数(相邻的两个数用空格隔开),并输出值为中间的整数的值(即恰有10个值小于它,恰有10个值大于它)。(注:可执行文件名为e5_3.exe)#include "stdio.h"void main()int a
52、21,i,tmp,j;printf("please input the number :n");for(i=0;i<21;i+) scanf("%d",&ai);for(i=0;i<21;i+) for(j=i+1;j<21;j+) if (ai<aj) tmp=ai; ai=aj; &
53、#160; aj=tmp; printf("the middle number is :n"); printf("%dn",a10);18.编一个程序,它能读入文件和中的所有整数,并把这些数按从小到大的次序写到文件中,文件中的相邻两个整数都用空格或换行符隔开, 相同的数只能写一次,十个数一行)。(注:可执行文件名为e9_2.exe)#include "stdio.h"#include "stdlib.h"in
54、t o=0; /*设置一个全局变量使o等于去掉重复数后的总的数据个数 */int clearsort(int a,int quantity) /*将重复的数去掉并且改掉总的数据个数*/int i,j,m;for(i=0;i<quantity-1;i+) for(j=i+1;j<quantity;j+) if(ai=aj) for(m=j+1;m<=quantity;m+) am-1=am;
55、0; quantity-; j-; o=quantity; return(quantity) ;void main(void)file *fp1,*fp2,*fp3;int a100,b100,i,x,n,j,p,tmp; system("cls"); /* 清屏 */if (fp1=fopen("f1.c",
56、"wb")=null) printf("the file f1.c can not open !n"); exit(0); printf("please input the number in f1.c:n"); x=9999; while (x!=-9999) scanf("%d",&x); if (x!=-9999) fwrite(&x,sizeof(int)
57、,1,fp1); fclose(fp1); if (fp2=fopen("f2.c","wb")=null) printf("the file f2.c can not open !n"); exit(0); printf("please input the number in f2.c:n"); x=9999; while (x!=-9999)
58、160; scanf("%d",&x); if (x!=-9999) fwrite(&x,sizeof(int),1,fp2); fclose(fp2); if (fp1=fopen("f1.c","rb")=null) printf("the file f1.c can not open !/n");
59、 exit(0); if (fp2=fopen("f2.c","rb")=null) printf("can not open the file f2.c!n"); exit(0); if (fp3=fopen("f3.c","wb")=null)
60、; printf("can not open the file f3.c!n"); exit(0); i=-1; while(!feof(fp1) fread(&a+i,sizeof(int),1,fp1); /*将fp1文件中的数据写入a数组中 */ fclose(fp1); i-; rewind(fp2); whi
61、le(!feof(fp2) fread(&a+i,sizeof(int),1,fp2); /*紧接着fp1 fp2也将数据写入a数组中*/ fclose(fp2); n=i; for(j=0;j<n;j+) /* 排序*/ for(p=j+1;p<n;p+) if (aj>ap) tmp=a
62、j; aj=ap; ap=tmp; clearsort(a,n); /*调用子函数 */ fwrite(a,sizeof(int),o,fp3); /*将数据写到文件fp3中*/ fclose(fp3); if(fp3=fopen("f3.c"
63、;,"rd")=null) printf("can not open f3.c !n"); exit(0); i=0; while(!feof(fp3) /*这里开始输出并且每行十个 */ &
64、#160; fread(&bi,sizeof(int),1,fp3); /*将fp3文件中的数据写到b数组中*/ printf("%d ",bi+); if(i%10=0) printf("n"); if (i>=o) break;
65、 printf("n"); 第十九题 编一c程序,它能读入一正整数n,并输出如下图形: 1 2 2 2
66、0; 3 3 3 3 3 . aaaa .aaaa bbbbbbb,. bbbbbbb .
67、; . nnnnnnn n . . . . . nnnnnnnnn (共2n-1个n) . bbbbbbbbb.bbbbbbbbbb aaaaaa.aaaaaaaa
68、; . . 3 3 3 3 3 2 2 2
69、160; 1当n>9时输出a,b c.:<=9时输出12345.9#include "stdio.h"void print(int num ,char shu,char row,int rows) /* num是要输出的字符的个数 shu要输出的字符 row 是空格 rows 是空格的个数 */int m,j;for(m=0;m<rows;m+)printf("%c ",row);j=m; for(;j<m+
70、num;j+)printf("%c ",shu); for(m=0;m<rows;m+)printf("%c ",row); /*到这里还没换行呢 */printf("n");void print11(int num ,int shu,char row,int rows) int m,j;for(m=0;m<rows;m+)printf("%c ",row);j=m; for(;j&
71、lt;m+num;j+)printf("%d ",shu); for(m=0;m<rows;m+)printf("%c ",row); printf("n");void main(void)int i,n,printnum,rows,j;char rownum,a52="abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz",printchar;int printchar1;printf("please input the number
72、 :n");scanf("%d",&n); for(i=1,printnum=1,printchar='1',rownum=' ',rows=n-i;i<=n;printnum+=2,i+,rows-,printchar+) if (i<=9)print(printnum,printchar,rownum,rows);else if (i>9) for(j=0;j<n-9;j+,printnum+=2,rows-,i+) print(printnum,
73、aj,rownum,rows); break; for(printnum-=4,i-=2,rows=1;i>=1;printnum-=2,i-,rows+) if (i>9) for(j=n-11;j>=0;j-,printnum-=2,rows+,i-) print(printnum,aj,rownum,rows); if (i<=9) for(printchar1=i,printnum=
74、2*i-1,rows=n-i;i>=0;printnum-=2,printchar1-,i-,rows+)print11(printnum,printchar1,rownum,rows); break; 20. 编一c程序,它能计算并输出读入的两个无符号整数m与n(mn,0<m<1050,0<n<1050)的差m-n。#include "stdio.h"#include "string.h"void main() static char m20,n20
75、,mn20; int nl,ml,ms,ns,mns,k,i,j,f; printf("please input two number (0):n"); scanf("%s",&m); scanf("%s",&n); ml=strlen(m); nl=strlen(n); if (ml<nl) | (m<n) strcpy(mn,m);k=ml; strcpy
76、(m,n);ml=nl; strcpy(n,mn);nl=k; printf("%s-%s=",m,n); for(i=ml-1,j=nl-1;i>=ml-nl-1;i-,j-) ni=nj; for(i=0;i<ml-nl;i+) ni='0' for(i=ml-1;i>=0;i-) ms=mi-48; ns=ni-48;
77、 if(ms>=ns) mns=ms-ns; f=0; else mns=ms+10-ns; f=-1; if(ms>=ns) mi=mns
78、+48; else mi=mns+48; mi-1+=f; k=0; while(mk='0') k+; for(i=k,j=0;i<ml;i+,j+) mnj=mi; printf("%sn",mn);第二十一题 加 编一c程序,它能以字
79、符串形式读入两个无符号正整数m和n(两个串各占一行),计算并输出这两个整数的和,其中m和n的值最大可为1000亿。(注:可执行文件名为e6_2.exe) 大于1000亿就超过了无符号长整型的数值范围 范围是01 0000 0000 0000无符号短整型 065535无符号长整形 042 9496 7295所以要数据类型转换 根据转换原则 char short -> int àunsigned ->long ->double unsignedsh
80、ort unsigned long float 所以依据这个我们就得转换成double#include "stdio.h"#include "string.h"void main() char m20,n20,mn20; int ml,nl,ms,ns,mns,k,i,j,f; printf("pleas
81、e enter 2 number string:n"); scanf("%s",&m); scanf("%s",&n); ml=strlen(m); nl=strlen(n); if (ml&l
82、t;nl | m<n) strcpy(mn,m);k=ml;strcpy(m,n);ml=nl;strcpy(n,mn);nl=k; printf("%s+%s=",m,n); for (i=ml-1,j=nl-1;i>=ml-nl-1;i-,j-) ni=nj; &
83、#160; for (i=0;i<ml-nl;i+) ni='0' for (i=ml-1;i>=0;i-) ms=mi-48; ns=ni-48; mns=ms+ns;
84、160; if (mns<10) f=0; else f=1; if (mns<10) mi+=ns; else mi+=ns-10; /*向前进位 */
85、0; mi-1+=f; /*向前一位进一 */ if(f=1) for (i=ml;i>0;i-)
86、60; mi=mi-1; m0='1' for(i=0;i<=ml;i+) printf("%c",mi);
87、0; else for(i=0;i<ml;i+) printf("%c",mi); printf("n");22.编一c程序,它能读入由空格隔开的5个正整数,对每个正整数n,判断,若n是完全数(即n=d1+d
88、2+.+dk,其中d1,d2,.dk是n的所有小于它的因子,如6的所有小于它的因子是1,2,3,6=1+2+3,即6是完全数),则输出yes,否则输出no。(注:可执行文件名为e7_2.exe)#include "stdio.h"void main() int a5,i,j,n; printf("please enter 5 number:n"); for (i=0;
89、i<5;i+) scanf("%d",&ai); for (i=0;i<5;i+) n=0; for (j=1;j<ai;j+) if (ai%j=0)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 孕期离婚协议模板定制与婚姻财产分割指导合同
- 离婚房产归女方协议书:女方权益保障范本
- 离婚协议书范本:无子女双方协议书
- 石家庄市二手房买卖交易合同终止后权益保障协议
- 离婚协议6865I版:财产分割及债务处理细则
- 城市综合体物业管理与能源采购合同
- 食品企业生产信息保密及食品安全责任合同
- 班组级安全培训内容模板课件
- 小班教学水果课件
- 2025年病理生理学乳腺组织病理变化模拟考试卷答案及解析
- 2025债权收购委托代理合同
- 2025年中国建筑集团招聘面试宝典与模拟题答案
- 2025年高考英语新课标Ⅱ卷点评及2026备考方向 课件
- 2025年学宪法、讲宪法知识竞赛题库及答案
- T/CTRA 01-2020废轮胎/橡胶再生油
- 2025广西专业技术人员公需科目培训考试答案
- 高中英语新课标3000词汇表(新高考)
- 中英文版送货单
- 中英文验货报告模板
- T∕CCFA 01030-2017 纤维级化学法循环再利用聚酯切片(PET)
- 放射科质量与安全管理考核标准
评论
0/150
提交评论