经典c语言程序设计例.pdf

上传人:白大夫 文档编号:5421701 上传时间:2020-05-05 格式:PDF 页数:62 大小:79.50KB
返回 下载 相关 举报
经典c语言程序设计例.pdf_第1页
第1页 / 共62页
经典c语言程序设计例.pdf_第2页
第2页 / 共62页
经典c语言程序设计例.pdf_第3页
第3页 / 共62页
经典c语言程序设计例.pdf_第4页
第4页 / 共62页
经典c语言程序设计例.pdf_第5页
第5页 / 共62页
点击查看更多>>
资源描述

《经典c语言程序设计例.pdf》由会员分享,可在线阅读,更多相关《经典c语言程序设计例.pdf(62页珍藏版)》请在三一文库上搜索。

1、经典 C语言程序设计 100 例 1-10 【程序 1】 题目:有 1、2、3、4 个数字,能组成多少个互不相同且无重复数字的三位数? 都是多少? 1.程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排 列后再去 掉不满足条件的排列。 2.程序源代码: main() int i,j,k; printf(“n“); for(i=1;i2)/*如果是闰年且月份大于2,总天数应该加一天 */ sum+; printf(“It is the %dth day.“,sum); - 【程序 5】 题目:输入三个整数x,y,z,请把这三个数由小到大输出。 1.程序分析:我们想办法把最小的

2、数放到x 上,先将 x 与 y 进行比较,如果 xy 则将 x 与 y 的值进行交换, 然后再用 x 与 z 进行比较,如果 xz 则将 x 与 z 的值进行交换, 这样能使 x 最小。 2.程序源代码: main() int x,y,z,t; scanf(“%d%d%d“, 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); - 【程序 6】 题目:用 * 号输出

3、字母 C的图案。 1.程序分析:可先用 * 号在纸上写出字母C,再分行输出。 2.程序源代码: #include “stdio.h“ main() printf(“Hello C-world!n“); printf(“ *n“); printf(“ *n“); printf(“ * n“); printf(“ *n“); - 【程序 7】 题目:输出特殊图案,请在c 环境中运行,看一看, Very Beautiful! 1.程序分析:字符共有256 个。不同字符,图形不一样。 2.程序源代码: #include “stdio.h“ main() char a=176,b=219; printf

4、(“%c%c%c%c%cn“,b,a,a,a,b); printf(“%c%c%c%c%cn“,a,b,a,b,a); printf(“%c%c%c%c%cn“,a,a,b,a,a); printf(“%c%c%c%c%cn“,a,b,a,b,a); printf(“%c%c%c%c%cn“,b,a,a,a,b); - 【程序 8】 题目:输出 9*9 口诀。 1.程序分析:分行与列考虑,共9 行 9 列, i 控制行, j 控制列。 2.程序源代码: #include “stdio.h“ main() int i,j,result; printf(“n“); for (i=1;ik ,但 n

5、 能被 k 整除,则应打印出k 的值,并用 n 除以 k 的商,作为 新的正整数你 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“, printf(“%d=“,n); for(i=2;i=90 分的同学用 A 表示, 60-89 分之间的用 B 表示, 60 分以下的用 C表示。 1.程序分析: (ab)?a:b 这是条件运算符

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

7、(“%d,%d“, if(num1=a/*第一天的桃子数是第2 天桃子数加 1 后的 2 倍*/ x2=x1; day-; printf(“the total is %dn“,x1); - 【程序 22】 题目:两个乒乓球队进行比赛, 各出三人。甲队为 a,b,c 三人,乙队为 x,y,z 三人。 已抽签决定 比赛名单。有人向队员打听比赛的名单。a 说他不和 x 比,c 说他不和 x,z 比,请编程序找出 三队赛手的名单。 1.程序分析:判断素数的方法:用一个数分别去除2 到 sqrt( 这个数 ),如果能被 整除, 则表明此数不是素数,反之是素数。 2.程序源代码: main() char

8、i,j,k;/*i是 a 的对手, j 是 b 的对手, k 是 c 的对手 */ for(i=x;i void main() char letter; printf(“please input the first letter of somedayn“); while (letter=getch()!=Y)/*当所按字母为 Y 时才结束 */ switch (letter) case S:printf(“please input second lettern“); if(letter=getch()=a) printf(“saturdayn“); else if (letter=getch(

9、)=u) printf(“sundayn“); else printf(“data errorn“); break; case F:printf(“fridayn“);break; case M:printf(“mondayn“);break; case T:printf(“please input second lettern“); if(letter=getch()=u) printf(“tuesdayn“); else if (letter=getch()=h) printf(“thursdayn“); else printf(“data errorn“); break; case W:

10、printf(“wednesdayn“);break; default: printf(“data errorn“); - 【程序 32】 题目: Press any key to change color , do you want to try it. Please hurry up! 1.程序分析: 2.程序源代码: #include void main(void) int color; for (color = 0; color void main(void) clrscr();/* 清屏函数 */ textbackground(2); gotoxy(1, 5);/*定位函数 */ c

11、printf(“Output at row 5 column 1n“); textbackground(3); gotoxy(20, 10); cprintf(“Output at row 10 column 20n“); - 【程序 34】 题目:练习函数调用 1. 程序分析: 2.程序源代码: #include void hello_world(void) printf(“Hello, world!n“); void three_hellos(void) int counter; for (counter = 1; counter void main(void) int color; fo

12、r (color = 1; color #include “math.h“ #define N 101 main() int i,j,line,aN; for(i=2;iaj) min=j; tem=ai; ai=amin; amin=tem; /*output data*/ printf(“After sorted n“); for(i=0;iend) a10=number; else for(i=0;inumber) temp1=ai; ai=number; for(j=i+1;j“); scanf(“%d“, printf(“40:The square for this number i

13、s %d n“,SQ(num); if(num=50) again=TRUE; else again=FALSE; - 【程序 47】 题目:宏 #define 命令练习 (2) 1.程序分析: 2.程序源代码: #include “stdio.h“ #define exchange(a,b) /*宏定义中允许包含两道衣裳命令的情形,此时必须 在最右边加上 “*/ int t; t=a; a=b; b=t; void main(void) int x=10; int y=20; printf(“x=%d; y=%dn“,x,y); exchange(x,y); printf(“x=%d; y=

14、%dn“,x,y); - 【程序 48】 题目:宏 #define 命令练习 (3) 1.程序分析: 2.程序源代码: #define LAG #define SMA y)?x:y #define MINIMUM(x,y) (xy)?y:x void main() int a=10,b=20; #ifdef MAX printf(“40: The larger one is %dn“,MAXIMUM(a,b); #else printf(“40: The lower one is %dn“,MINIMUM(a,b); #endif #ifndef MIN printf(“40: The low

15、er one is %dn“,MINIMUM(a,b); #else printf(“40: The larger one is %dn“,MAXIMUM(a,b); #endif #undef MAX #ifdef MAX printf(“40: The larger one is %dn“,MAXIMUM(a,b); #else printf(“40: The lower one is %dn“,MINIMUM(a,b); #endif #define MIN #ifndef MIN printf(“40: The lower one is %dn“,MINIMUM(a,b); #else

16、 printf(“40: The larger one is %dn“,MAXIMUM(a,b); #endif - 【程序 50】 题目: #include 的应用练习 1.程序分析: 2.程序源代码: test.h 文件如下: #define LAG #define SMA 4; c=(0=RIGHT) dx1=-dx1; if(y1=BOTTOM) dy1=-dy1; if(x2=RIGHT) dx2=-dx2; if(y2=BOTTOM) dy2=-dy2; if(+countLINES) setcolor(color); color=(color=MAXCOLOR)?0:+color

17、; closegraph(); 【程序 61】 题目:打印出杨辉三角形(要求打印出10 行如下图) 1.程序分析: 1 1 1 1 2 1 13 31 146 4 1 1510105 1 2.程序源代码: main() int i,j; int a1010; printf(“n“); for(i=0;in2) swap(pointer1,pointer2); if(n1n3) swap(pointer1,pointer3); if(n2n3) swap(pointer2,pointer3); printf(“the sorted numbers are:%d,%d,%dn“,n1,n2,n3)

18、; swap(p1,p2) int *p1,*p2; int p; p=*p1;*p1=*p2;*p2=p; - 【程序 67】 题目:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出 数组。 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(*parray;p-) *p=*(p-1); *array=ar

19、ray_end; m-; if(m0) move(array,n,m); - 【程序 69】 题目:有 n 个人围成一圈,顺序排号。从第一个人开始报数(从1 到 3 报数) , 凡报到 3 的人退出 圈子,问最后留下的是原来第几号的那位。 1. 程序分析: 2.程序源代码: #define nmax 50 main() int i,k,m,n,numnmax,*p; printf(“please input the total of numbers:“); scanf(“%d“, p=num; for(i=0;in“); for(i=0;idata=num; ptr-next=(link)ma

20、lloc(sizeof(node); if(i=4) ptr-next=NULL; else ptr=ptr-next; ptr=head; while(ptr!=NULL) printf(“The value is =%dn“,ptr-data); ptr=ptr-next; - 【程序 73】 题目:反向输出一个链表。 1.程序分析: 2.程序源代码: /*reverse output a list*/ #include “stdlib.h“ #include “stdio.h“ struct list int data; struct list *next; ; typedef stru

21、ct list node; typedef node *link; void main() link ptr ,head,tail; int num,i; tail=(link)malloc(sizeof(node); tail-next=NULL; ptr=tail; printf(“nplease input 5 data=n“); for(i=0;idata=num; head=(link)malloc(sizeof(node); head-next=ptr; ptr=head; ptr=ptr-next; while(ptr!=NULL) printf(“The value is =%

22、dn“,ptr-data); ptr=ptr-next; - 【程序 74】 题目:连接两个链表。 1.程序分析: 2.程序源代码: #include “stdlib.h“ #include “stdio.h“ struct list int data; struct list *next; ; typedef struct list node; typedef node *link; link delete_node(link pointer,link tmp) if (tmp=NULL) /*delete first node*/ return pointer-next; else if(

23、tmp-next-next=NULL)/*delete last node*/ tmp-next=NULL; else /*delete the other node*/ tmp-next=tmp-next-next; return pointer; void selection_sort(link pointer,int num) link tmp,btmp; int i,min; for(i=0;idata; btmp=NULL; while(tmp-next) if(mintmp-next-data) min=tmp-next-data; btmp=tmp; tmp=tmp-next;

24、printf(“40: %dn“,min); pointer=delete_node(pointer,btmp); link create_list(int array,int num) link tmp1,tmp2,pointer; int i; pointer=(link)malloc(sizeof(node); pointer-data=array0; tmp1=pointer; for(i=1;inext=NULL; tmp2-data=arrayi; tmp1-next=tmp2; tmp1=tmp1-next; return pointer; link concatenate(li

25、nk pointer1,link pointer2) link tmp; tmp=pointer1; while(tmp-next) tmp=tmp-next; tmp-next=pointer2; return pointer1; void main(void) int arr1=3,12,8,9,11; link ptr; ptr=create_list(arr1,5); selection_sort(ptr ,5); - 【程序 75】 题目:放松一下,算一道简单的题目。 1.程序分析: 2.程序源代码: main() int i,n; for(i=1;i1) break; if(n%2

26、=0) printf(“Even=“); sum=dcall(peven,n); else printf(“Odd=“); sum=dcall(podd,n); printf(“%f“,sum); float peven(int n) float s; int i; s=1; for(i=2;iage) q=p+; m=q-age; printf(“%s,%d“,(*q).name,(*q).age); - 【程序 79】 题目:字符串排序。 1.程序分析: 2.程序源代码: main() char *str120,*str220,*str320; char swap(); printf(“p

27、lease input three stringsn“); scanf(“%s“,str1); scanf(“%s“,str2); scanf(“%s“,str3); if(strcmp(str1,str2)0) swap(str1,str2); if(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

28、; char *p20; strcpy(p,p1);strcpy(p1,p2);strcpy(p2,p); - 【程序 80】 题目:海滩上有一堆桃子, 五只猴子来分。 第一只猴子把这堆桃子凭据分为五份, 多了一个,这只 猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平 均分成五份,又多了 一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只 猴子都是这样做的, 问海滩上原来最少有多少个桃子? 1.程序分析: 2.程序源代码: main() int i,m,j,k,count; for(i=4;i=1000 - 【程序 82】 题目:八进制转换为十进制 1.程序分析:

29、2.程序源代码: main() char *p,s6;int n; p=s; gets(p); n=0; while(*(p)!=0) n=n*8+*p-0; p+; printf(“%d“,n); - 【程序 83】 题目:求 07 所能组成的奇数个数。 1.程序分析: 2.程序源代码: main() long sum=4,s=4; int j; for(j=2;jsqrt(b) d=a-b; else break; for(c=2;csqrt(d) printf(“%d=%d+%dn“,a,b,d); - 【程序 85】 题目:判断一个素数能被几个9 整除 1.程序分析: 2.程序源代码:

30、 main() long int m9=9,sum=9; int zi,n1=1,c9=1; scanf(“%d“, while(n1!=0) if(!(sum%zi) n1=0; else m9=m9*10; sum=sum+m9; c9+; printf(“%ld,can be divided by %d “9“,sum,c9); - 【程序 86】 题目:两个字符串连接程序 1.程序分析: 2.程序源代码: #include “stdio.h“ main() char a=“acegikm“; char b=“bdfhjlnpq“; char c80,*p; int i=0,j=0,k=

31、0; while(ai!=0 for(i=1;i=0;i-) printf(“%d“,aai); - 【程序 90】 题目:专升本一题,读结果。 1.程序分析: 2.程序源代码: #include “stdio.h“ #define M 5 main() int aM=1,2,3,4,5; int i,j,t; i=0;j=M-1; while(ii) printf(“please input a little smaller.n“); scanf(“%d“, else printf(“please input a little bigger.n“); scanf(“%d“, end=cloc

32、k(); b=time(NULL); printf(“1: It took you %6.3f secondsn“,var=(double)(end-start)/18.2); printf(“1: it took you %6.3f secondsnn“,difftime(b,a); if(var16) gotoxy(41,4+i-17); printf(“ “); gotoxy(42,4+i-17); i+; sum=sum+chm; printf(“%10s %-14s %6.1fn“,chtime,chshop,chm); gotoxy(1,23);printf(“|- -|“); g

33、otoxy(1,24);printf(“| |“); gotoxy(1,25);printf(“|- -|“); gotoxy(10,24);printf(“total is %8.1f$“,sum); fclose(fp); gotoxy(49,24);printf(“press any key to.“);getch();goto pp; else while(ch0!=r) if(j15) len=len+1; j=11; strcpy(ch1,“); j=j-2; strncat(ch1,chtime,len); strcpy(chtime,“); strncat(chtime,ch1

34、,len-1); gotoxy(13,7);printf(“ “); gotoxy(13,7);printf(“%s“,chtime);ch0=getch(); if(ch0=9) goto mm; if(ch0=27) exit(1); gotoxy(3,24);printf(“ “); gotoxy(13,10); j=0; ch0=getch(); while(ch0!=r) if (j=aci=cj;cj=t; printf(“n C file is:n“); fp=fopen(“C“,“w“); for(i=0;in;i+) putc(ci,fp); putchar(ci); fcl

35、ose(fp); - 【程序 100】 题目:有五个学生,每个学生有3 门课的成绩,从键盘输入以上数据(包括学生 号,姓名,三门课成绩) ,计算出 平均成绩,况原有的数据和计算出的平均分数存放在磁盘文件“stud“ 中。 1.程序分析: 2.程序源代码: #include “stdio.h“ struct student char num6; char name8; int score3; float avr; stu5; main() int i,j,sum; FILE *fp; /*input*/ for(i=0;i5;i+) printf(“n please input No. %d score:n“,i); printf(“stuNo:“); scanf(“%s“,stui.num); printf(“name:“); scanf(“%s“,stui.name); sum=0; for(j=0;j3;j+) printf(“score %d.“,j+1); scanf(“%d“, sum+=stui.scorej; stui.avr=sum/3.0; fp=fopen(“stud“,“w“); for(i=0;i5;i+) if(fwrite( fclose(fp);

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1