1、 程序员面试无敌-程序算法 -C 程序 100 例面试 程序员的时候,很多人喜欢出几个程序,一般他们都是从这里抄的. 就算不是,也是大同小异。只要下面的这些会了,记住了,一般的也就 PASS 了。为了查看方便,故贴出来。因网上流传很多。但不知最初的作者是谁。故未写出。【 程序 1】题目:有 1、2 、3 、4 个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?1.程序分析:可填在百位、十位、个位的数字都是 1、2 、3、4。组成所有的排列后再去掉不满足条件的排列。 2.程序源代码:main()int i,j,k;printf(“n“);for(i=1;i2)/*如果是闰年且月份大于
2、2,总天数应该加一天*/sum+;printf(“It is the %dth day.“,sum);=【程序 5】题目:输入三个整数 x,y,z,请把这三个数由小到大输出。1.程序分析:我们想办法把最小的数放到 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 的值*/
3、if(yz)t=y;y=z;z=t;/*交换 z,y 的值*/printf(“small to big: %d %d %dn“,x,y,z);=【程序 6】题目:用*号输出字母 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
4、 个。不同字符,图形不一样。 2.程序源代码:#include “stdio.h“main()char a=176,b=219;printf(“%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 “st
5、dio.h“main()int i,j,result;printf(“n“);for (i=1;ik,但 n 能被 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
6、表示,60 分以下的用 C 表示。1.程序分析:(ab)?a:b 这是条件运算符的基本例子。2.程序源代码:main()int score;char grade;printf(“please input a scoren“);scanf(“%d“,grade=score=90?A:(score=60?B:C);printf(“%d belongs to %c“,score,grade);=【程序 16】题目:输入两个正整数 m 和 n,求其最大公约数和最小公倍数。-4 回复:经典源程序 100 例 1.程序分析:利用辗除法。2.程序源代码:main()int a,b,num1,num2,tem
7、p;printf(“please input two numbers:n“);scanf(“%d,%d“,if(num1 temp=num1;num1=num2; num2=temp;a=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);=【程序 17】题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。1.程序分析:利用 while 语句, 条件为输入的字符不为n.2.
8、程序源代码:#include “stdio.h“main()char c;int letters=0,space=0,digit=0,others=0;printf(“please input some charactersn“);while(c=getchar()!=n)if(c=a/*第一天的桃子数是第 2 天桃子数加 1 后的 2 倍*/x2=x1;day-;printf(“the total is %dn“,x1);=【程序 22】题目:两个乒乓球队进行比赛,各出三人。甲队为 a,b,c 三人,乙队为 x,y,z 三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a 说他不和 x 比
9、,c 说他不和 x,z 比,请编程序找出三队赛手的名单。 1.程序分析:判断素数的方法:用一个数分别去除 2 到 sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。 2.程序源代码:main()char i,j,k;/*i 是 a 的对手, j 是 b 的对手,k 是 c 的对手*/for(i=x;ivoid main()char letter;printf(“please input the first letter of somedayn“);while (letter=getch()!=Y)/*当所按字母为 Y 时才结束*/ switch (letter)case S:p
10、rintf(“please input second lettern“);if(letter=getch()=a)printf(“saturdayn“);else if (letter=getch()=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“);
11、else if (letter=getch()=h)printf(“thursdayn“);else printf(“data errorn“);break;case W: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 voi
12、d main(void)clrscr();/*清屏函数 */textbackground(2);gotoxy(1, 5);/*定位函数*/cprintf(“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 count
13、er;for (counter = 1; counter void main(void)int color;for (color = 1; color #include “math.h“#define N 101main()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;elsefor(i=0;inumber)temp1=ai;ai=number;for(j=i+1;j4;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;closegraph(); -12 回复:经典源程序 100 例 【 程序 61】题目:打印出杨辉三角形(要求打印出 10 行如下图) 1.程序分析:11 11 2 11 3 3 11 4 6 4 11 5 10 10 5 1 2.程序源代码:main()int i,j;int a1010;