C语言经典编程24例【必看】

上传人:无*** 文档编号:28045774 上传时间:2021-08-23 格式:DOC 页数:15 大小:55.51KB
收藏 版权申诉 举报 下载
C语言经典编程24例【必看】_第1页
第1页 / 共15页
C语言经典编程24例【必看】_第2页
第2页 / 共15页
C语言经典编程24例【必看】_第3页
第3页 / 共15页
资源描述:

《C语言经典编程24例【必看】》由会员分享,可在线阅读,更多相关《C语言经典编程24例【必看】(15页珍藏版)》请在装配图网上搜索。

1、在学校C语言考试中会有两道编程题,大概一道是自定义函数,一个是一个整体函数。而一道编程题得分格式:即你一点不会将他抄上去也会有分:一:头文件现在大家用的仅为一下,全填上#include math.h #include stdio.h #include 二、主函数 main() Int i,j; 声明变量 Char a,b;若有自定义函数则Void/int/char/ 函数名(参数1,参数2.) Int m,n;并在main函数中声明变量后加Void/int/char/ 函数名(参数1,参数2.);经典语句:if else语句必会While,for,switch,dowhile,至少会一个。一下

2、为24道经典例题,大家可以参详一下,头文件有的没加,自添#include math.h #include stdio.h #include 【程序1】 题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? 1.程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。 2.程序源代码: main() int i,j,k; printf(n); for(i=1;i5;i+) *以下为三重循环*/ for(j=1;j5;j+) for (k=1;k5;k+) if (i!=k&i!=j&j!=k) /*确保i、j、k三位互不相

3、同*/ printf(%d,%d,%dn,i,j,k); = 【程序2】 题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少? 1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后 的结果满足如下条件,即是结果。请看具体分析: 2.程序源代码: #include math.h main() long int i,x,y,z; for (i=1;iy则将x与y的值进行交换, 然后再用x与z进行比较,如果xz则将x与z的值进行交换,这样能使x最小。 2.程序源代码: main() int x,y,z,t; s

4、canf(%d%d%d,&x,&y,&z); if (xy) t=x;x=y;y=t; /*交换x,y的值*/ if(xz) t=z;z=x;x=t;/*交换x,z的值*/ if(yz) t=y;y=z;z=t;/*交换z,y的值*/ printf(small to big: %d %d %dn,x,y,z); = 【程序4】 题目:输出9*9口诀。 1.程序分析:分行与列考虑,共9行9列,i控制行,j控制列。 2.程序源代码: #include stdio.h main() int i,j,result; printf(n); for (i=1;i10;i+) for(j=1;j10;j+)

5、 result=i*j; printf(%d*%d=%-3d,i,j,result);/*-3d表示左对齐,占3位*/ printf(n);/*每一行后换行*/ = 【程序5】 题目:判断101-200之间有多少个素数,并输出所有素数。 1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除, 则表明此数不是素数,反之是素数。 2.程序源代码: #include math.h main() int m,i,k,h=0,leap=1; printf(n); for(m=101;m=200;m+) k=sqrt(m+1); for(i=2;i=k;i+) if(m%i=

6、0) leap=0;break; if(leap) printf(%-4d,m);h+; if(h%10=0) printf(n); leap=1; printf(nThe total is %d,h); = 【程序6】 题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数 本身。例如:153是一个“水仙花数”,因为153=1的三次方5的三次方3的三次方。 1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。 2.程序源代码: main() int i,j,k,n; printf(water flowernumber is:);

7、 for(n=100;n1000;n+) i=n/100;/*分解出百位*/ j=n/10%10;/*分解出十位*/ k=n%10;/*分解出个位*/ if(i*100+j*10+k=i*i*i+j*j*j+k*k*k) printf(%-5d,n); printf(n); = 【程序7】 题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。 程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成: (1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。 (2)如果nk,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整

8、数你n, 重复执行第一步。 (3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。 2.程序源代码: /* zheng int is divided yinshu*/ main() int n,i; printf(nplease input a number:n); scanf(%d,&n); printf(%d=,n); for(i=2;i=90分的同学用A表示,60-89分之间的用B表示, 60分以下的用C表示。 1.程序分析:(ab)?a:b这是条件运算符的基本例子。 2.程序源代码: main() int score; char grade; printf(please in

9、put a scoren); scanf(%d,&score); grade=score=90?A:(score=60?B:C); printf(%d belongs to %c,score,grade); = 【程序9】 题目:输入两个正整数m和n,求其最大公约数和最小公倍数。 1.程序分析:利用辗除法。 2.程序源代码: main() int a,b,num1,num2,temp; printf(please input two numbers:n); scanf(%d,%d,&num1,&num2); if(num1 temp=num1; num1=num2; num2=temp; a=

10、num1;b=num2; while(b!=0)/*利用辗除法,直到b为0为止*/ temp=a%b; a=b; b=temp; printf(gongyueshu:%dn,a); printf(gongbeishu:%dn,num1*num2/a); = 【程序9】 题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。 1.程序分析:利用while语句,条件为输入的字符不为n. 2.程序源代码: #include stdio.h main() char c; int letters=0,space=0,digit=0,others=0; printf(please inp

11、ut some charactersn); while(c=getchar()!=n) if(c=a&c=A&c=0&c=9) digit+; else others+; printf(all in all:char=%d space=%d digit=%d others=%dn,letters, space,digit,others); = 【程序10】 题目:求s=a+aa+aaa+aaaa+aa.a的值,其中a是一个数字。例如2+22+222+2222+22222(此时 共有5个数相加),几个数相加有键盘控制。 1.程序分析:关键是计算出每一项的值。 2.程序源代码: main() in

12、t a,n,count=1; long int sn=0,tn=0; printf(please input a and nn); scanf(%d,%d,&a,&n); printf(a=%d,n=%dn,a,n); while(count=n) tn=tn+a; sn=sn+tn; a=a*10; +count; printf(a+aa+.=%ldn,sn); = 【程序11】 题目:一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=123.编程 找出1000以内的所有完数。 1. 程序分析:请参照程序-上页程序14. 2.程序源代码: main() static int k1

13、0; int i,j,n,s; for(j=2;j0)x1=(x2+1)*2;/*第一天的桃子数是第2天桃子数加1后的2倍*/x2=x1;day-;printf(the total is %dn,x1);=【题目:利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。1.程序分析:2.程序源代码:#include stdio.hmain()int i=5;void palin(int n);printf(40:);palin(i);printf(n);void palin(n)int n;char next;if(naj) min=j;tem=ai;ai=amin;amin=tem;/

14、*output data*/printf(After sorted n);for(i=0;iprintf(%5d,ai);=【程序17】题目:求一个3*3矩阵对角线元素之和 1.程序分析:利用双重for循环控制输入二维数组,再将aii累加后输出。2.程序源代码:main()float a33,sum=0;int i,j;printf(please input rectangle element:n);for(i=0;i3;i+)for(j=0;j3;j+)scanf(%f,&aij);for(i=0;i3;i+)sum=sum+aii;printf(duijiaoxian he is %6.2

15、f,sum);=【程序18】题目:有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。1. 程序分析:首先判断此数是否大于最后一个数,然后再考虑插入中间的数的情况,插入后此元素之后的数,依次后移一个位置。 2.程序源代码:main()int a11=1,4,6,9,13,16,19,28,40,100;int temp1,temp2,number,end,i,j;printf(original array is:n);for(i=0;iend)a10=number;elsefor(i=0;inumber)temp1=ai;ai=number;for(j=i+1;j11;j+)

16、temp2=aj;aj=temp1;temp1=temp2;break;for(i=0;i11;i+)printf(%6d,ai);=【程序19】 题目:打印出杨辉三角形(要求打印出10行如下图) 1.程序分析: 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 2.程序源代码: main() int i,j; int a1010; printf(n); for(i=0;i10;i+) ai0=1; aii=1; for(i=2;i10;i+) for(j=1;j aij=ai-1j-1+ai-1j; for(i=0;i10;i+) for(j=0;j=i

17、;j+) printf(,aij); printf(n); = 【程序20】 题目:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。 1.程序分析:谭浩强的书中答案有问题。 2.程序源代码: main() int number10; input(number); max_min(number); output(number); input(number) int number10; int i; for(i=0;i*max) max=p; else if(*p*min) min=p; k=*max; l=*min; *p=array0;array0=l;l=*p; *p=

18、array9;array9=k;k=*p; return; output(array) int array10; int *p; for(p=array;p printf(%d,*p); printf(%dn,array9); = 【程序21】 题目:写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度。 1.程序分析: 2.程序源代码: main() int len; char *str20; printf(please input a string:n); scanf(%s,str); len=length(str); printf(the string has %d

19、characters.,len); length(p) char *p; int n; n=0; while(*p!=0) n+; p+; return n; 【程序22】 题目:编写input()和output()函数输入,输出5个学生的数据记录。 1.程序分析: 2.程序源代码: #define N 5 struct student char num6; char name8; int score4; stuN; input(stu) struct student stu; int i,j; for(i=0;i printf(n please input %d of %dn,i+1,N);

20、 printf(num: ); scanf(%s,stui.num); printf(name: ); scanf(%s,stui.name); for(j=0;j3;j+) printf(score %d.,j+1); scanf(%d,&stui.scorej); printf(n); print(stu) struct student stu; int i,j; printf(nNo. Name Sco1 Sco2 Sco3n); for(i=0;i printf(%-6s%-10s,stui.num,stui.name); for(j=0;j0) swap(str1,str2); if

21、(strcmp(str1,str3)0) swap(str1,str3); if(strcmp(str2,str3)0) swap(str2,str3); printf(after being sortedn); printf(%sn%sn%sn,str1,str2,str3); char swap(p1,p2) char *p1,*p2; char *p20; strcpy(p,p1);strcpy(p1,p2);strcpy(p2,p); = 【程序24】 题目:两个字符串连接程序 1.程序分析: 2.程序源代码: #include stdio.h main() char a=acegikm; char b=bdfhjlnpq; char c80,*p; int i=0,j=0,k=0; while(ai!=0&bj!=0) if (ai ck=ai;i+; else ck=bj+; k+; ck=0; if(ai=0) p=b+j; else p=a+i; strcat(c,p); puts(c);

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!