您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 项目/工程管理 > 必须会的C语言经典程序
1、输出9*9口诀。共9行9列,i控制行,j控制列。#includestdio.h#includeconio.hintmain(){inti,j,result;for(i=1;i10;i++){for(j=1;j10;j++){result=i*j;printf(%d*%d=%-3d,i,j,result);//-3d表示左对齐,占3位}printf(\n);//每一行后换行}getch();return0;}2、古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?兔子的规律为数列1,1,2,3,5,8,13,21....#includestdio.h#includeconio.hintmain(){longf1,f2;inti;f1=f2=1;for(i=1;i=20;i++){printf(%12ld%12ld,f1,f2);if(i%2==0){printf(\n);//控制输出,每行四个}f1=f1+f2;//前两个月加起来赋值给第三个月f2=f1+f2;//前两个月加起来赋值给第三个月}getch();return0;}3、判断101-200之间有多少个素数,并输出所有素数及素数的个数。程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。*#includestdio.h#includestdlib.h#includeconio.h#includemath.hintmain(){intm,i,k,h=0,leap=1;printf(\n);for(m=101;m=200;m++){k=(int)sqrt(m+1);for(i=2;i=k;i++){if(m%i==0){leap=0;break;}}if(leap)//内循环结束后,leap依然为1,则m是素数{printf(%-4d,m);h++;if(h%10==0){printf(\n);}}leap=1;}printf(\nThetotalis%d,h);getch();return0;}4、一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3。编程找出1000以内的所有完数。#includestdio.h#includeconio.hintmain(){staticintk[10];inti,j,n,s;for(j=2;j1000;j++){n=-1;s=j;for(i=1;ij;i++){if((j%i)==0){n++;s=s-i;k[n]=i;}}if(s==0){printf(%disawanshu:,j);for(i=0;in;i++){printf(%d,,k[i]);}printf(%d\n,k[n]);}}getch();return0;}5、将一个4×4的数组进行逆时针旋转90度后输出,要求原始数组的数据随机输入,新数组以4行4列的方式输出。(改为M×Md)#includeconio.h#includestdio.h#includestdlib.hintmain(){inta[4][4];//a存放原始数组数据intb[4][4];//b存放旋转后数组数据inti,j;for(i=0;i4;i++){for(j=0;j4;j++){a[i][j]=rand();}}for(i=0;i4;i++){for(j=0;j4;j++){printf(%d\t,a[i][j]);}printf(\n);}for(i=0;i4;i++){for(j=0;j4;j++){b[3-j][i]=a[i][j];}}printf(\n);printf(\n);printf(\n);for(i=0;i4;i++){for(j=0;j4;j++){printf(%d\t,b[i][j]);}printf(\n);}getch();return0;}通用方法#includeconio.h#includestdio.h#includestdlib.h#defineM8intmain(){inta[M][M];//a存放原始数组数据intb[M][M];//b存放旋转后数组数据inti,j;for(i=0;iM;i++){for(j=0;jM;j++){a[i][j]=rand();}}for(i=0;iM;i++){for(j=0;jM;j++){printf(%d\t,a[i][j]);}printf(\n);}for(i=0;iM;i++){for(j=0;jM;j++){b[M-1-j][i]=a[i][j];}}printf(\n);printf(\n);printf(\n);for(i=0;iM;i++){for(j=0;jM;j++){printf(%d\t,b[i][j]);}printf(\n);}getch();return0;}6、编程打印直角杨辉三角形#includestdio.h#includestdlib.h#includeconio.hintmain(){inti,j,a[8][8];for(i=0;i8;i++){for(j=0;j8;j++){a[i][j]=1;}}for(i=2;i8;i++){for(j=1;ji;j++){a[i][j]=a[i-1][j]+a[i-1][j-1];}}for(i=0;i8;i++){for(j=0;ji+1;j++){printf(%d\t,a[i][j]);}printf(\n);}getch();return0;}7、通过键盘输入M名学生N门课程的成绩,分别求每个学生的平均成绩和每门课程的平均成绩。要求所有成绩均放入一个I行J列的数组中,使用随机函数生成所有学生的成绩(60≤成绩≤100)其中最后二列分别放每个学生的总成绩和平均成绩,最后一行每门课程的平均成绩,求所有学生的平均分。(可把计算出的数据存入文件)。#includestdio.h#includestdlib.h#includeconio.h#defineM10#defineN6intmain(){floatsc[M+1][N+2]={0},scsum;inti,j;for(i=0;iM;i++){for(j=0;jN;j++){sc[i][j]=60+rand()%41;}}for(i=0;iM;i++){for(j=0;jN;j++){printf(%.0f\t,sc[i][j]);}printf(\n);}for(i=0;iM;i++){scsum=0;for(j=0;jN;j++){scsum+=sc[i][j];}sc[i][j]=scsum;sc[i][j+1]=scsum/N;}for(j=0;jN;j++){scsum=0;for(i=0;iM;i++){scsum+=sc[i][j];}sc[M][j]=scsum/M;}for(i=0;iM;i++){for(j=0;jN+2;j++){printf(%.2f\t,sc[i][j]);}printf(\n);}for(j=0;jN;j++){printf(%.2f\t,sc[M][j]);}getch();return0;}8、完善程序,实现将输入的字符串反序输出,如输入windows输出swodniw。#includestring.h#includestdio.h#includeconio.hintmain(){charch[1024],ct;inti,j,k;printf(Enterastring:);gets(ch);k=strlen(ch);for(i=0,j=k-1;ik/2;i++,j--){ct=ch[i];ch[i]=ch[j];ch[j]=ct;}puts(ch);getch();return0;}指针法:#includestdio.h#includestring.h#includeconio.hvoidfun1(char*s)`{inti,j,k;charct;k=strlen(s);for(i=0,j=k-1;ik/2;i++,j--){ct=*(s+i);*(s+i)=*(s+j);*(s+j)=ct;}}intmain(){charch[1024],*p,i,j;printf(inputstr:\n);gets(ch);fun1(ch);puts(ch);getch();return0;}9、下面程序的功能是从字符数组中删除指定的字符。#includestdio.h#includeconio.h#includestring.hintmain(){charch[80],cde;intj,k;printf(Enterwilldeletecharacter:);cde=getche();printf(\nEnterastring:);gets(ch);for(j=0,k=0;ch[j]!='\0';j++){if(ch[j]!=cde){ch[k++]=ch[j];}}ch[k]='\0';puts(ch);getch();return0;}10、编写一个voidsort(int*x,intn)实现将x数组中的n个数据从大到小排序。n及数组元素在主函数中输入。#includeconio.h#includestdlib.h#includestdio.h#defineM20voidsort(intx[],intn){inti,j,k,t;for(i=0;in-1;i++){for(j=0;jn-1;j++){if(x[j]x[j+1]){t=x[j];x[j]=x[j+1];x[j+1]=t;}}}}intmain(){int*p,i,x[M];p=x;printf(produce%dnumbers\n,M);for(i=0;iM;i++){*p++=rand();}p=x;sort(p,M);for(;px+M;){printf(%d\t,*p++);}getch();return0;}11、编写函数,利用下面公式计算π。9473523173523152313112计算π的近似值,当某一项的值小于10-8时,输出运算结果。#includestdio.h#includeconio.hdoublealpi(doubleeps)//eps为允许误差{intm=1;doubletemp=1.0,s=0;while(temp=eps){s+=temp;temp=temp*m/(2*m+1);m++;}return(2*s);}intmain(){doubleeps=1.0e-8,pi;printf(pi=%lf\n,alpi(eps));getch();return0;}12、已知数组k中的元素已按由小到大顺序排列,以下程序的功能是将输入的一个数n插入数组k中,插入后,数组k中的元素仍然由小到大顺序排列#includeconio.h#includestdio.h#includestdlib.h#defineM10voidsort(intx[],intn){inti,j,k;for(i=0;in;i++){for(j=0;jn-1;j++){if(x[j]x[j+1]){k=x[j];x[j]=x[j+1];x[j+1]=k;}}}}intmain(){intk[M];inti,j=M-5,n,p1=0,p2=0;printf(produce%dnumber:\n,j);for(i=0;ij;i++){k[i]=rand()%99+1;}sort(k,j);for(i=0;ij;i++){
本文标题:必须会的C语言经典程序
链接地址:https://www.777doc.com/doc-5523240 .html