C语言(必背程序,算法,题目)重要_第1页
C语言(必背程序,算法,题目)重要_第2页
C语言(必背程序,算法,题目)重要_第3页
C语言(必背程序,算法,题目)重要_第4页
已阅读5页,还剩81页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

内包括经典题目,经典程序与算法(你值得拥有)【程序ッ题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?.程序分析:可填在百位、十位、个位的数字都是1、2、3、4〇组成所有的排列后再去掉不满足条件的排列。.程序源代码:main(){intij,k;printf("\n");for(i=l;i<5;i++)/・以下为三重循环ッfor(j=l;j<5;j++)for(k=l;k<5;k++){if(i!=k&&i!=j&&j!=k)/・确保i、j、k三位互不相同・/printf("%d,%d,%d\nM,iJJc);})【程序2】题冃:企业发放的奖金根据利润提成。利润⑴低ア或等于10万元时,奖金可提10%:利润髙于10万元,低于20万元时,低于10万元的部分按10%提成,髙于10万元的部分,可可提成フ.5%;20万到40万之间时,髙于20万元的部分,可提成5%:40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,髙于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?.程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。.程序源代码:main(){longinti;intbonus1,bonus2,bonus4,bonus6,bonus10,bonus;scanf(H%Id",&i);bonus1=100000*0.1;bonus2=bonus1+100000*0.75;bonus4=bonus2+200000*0.5;bonus6=bonus4+200000*0.3;bonus10=bonus6+400000*0.15;if(i<=100000)bonus=i*0.1;elseif(i<=200000)bonus二bonusl+(i-100000)*0.075;elseif(i<=400000)bonus=bonus2+(i-200000)*0.05;elseif(i<=600000)bonus=bonus4+(i-400000)*0.03;elseif(i<=1000000)bonus=bonus6+(i-6(X)(X)0)*0.015;elsebonus=bonusl(h-(i-1000000)*0.01;printf("bonus=%d,',bonus);)【程序3】题目:ー个整数,它加上100后是ー个完全平方数,再加上168又是ー个完全平方数,请问该数是多少?1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后的结果满足如下条件,即是结果。请看具体分析:.程序源代码:#include"math.h"main(){longinti,x,y,z;for(i=l;i<l0000();i++){x=sqrt(i+100);/*x为加上100后开方后的结果・/y=sqrt(i+268);/*y为再加上168后开方后的结果・/if(x*x==i+100&&y*y==i+268)/*如果一个数的平方根的平方等于该数,这说明此数是完全平方数・/printf("\n%ld\n",i);}]【程序4】题冃:输入某年某月某日,判断这一天是这一年的第几天?.程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于3时需考虑多加一天。.程序源代码:main(){intday,month,year,sum.leap;printf("\npleaseinputyear,month,day\nM);scanf(H%d,%d,%d,',&year,&month,&day);switch(month)/・先计算某月以前月份的总天数・/{casel:sum=0;break;case2:sum=31;break;case3:sum=59;break;case4:sum=90;break;case5:sum=120;break;case6:sum=151;break;case7:sum=181;break;case8:sum=212;break;case9:sum=243;break;case10:sum=273;break;case11:sum=304;break;case12:sum=334;break;defauIt:printf(Mdataerror");break;|sum=sum+day;/・再加上某天的天数・/if(year%400==0ll(year%4=0&&year%100!=〇))/・判断是不是闰年・/Ieap=1;elseleap=O;if(leap==l&&month>2)/・如果是闰年且月份大于2,总天数应该加一天・/sum++;printf(MItisthe%dthday.",sum);)【程序5】题冃:输入三个整数xyz,请把这三个数由小到大输出。.程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。.程序源代码:main(){intx,y,z,t;scanf("%d%d%d",&x,&y,&z);if(x>y){t=x;x=y;y=t;}/・交换x,y的值・/if(x>z){t=z;z=x;x=l;}/・交换x,z的值・/if(y>z){仁y;y=Z;Z=t;}/・交换Z,y的值・/printf("smalltobig:%d%d%d\n",x,y,z);}【程序6】题目:用・号输出字母C的图案。.程序分析:可先用卡号在纸上写出字母C,再分行输出。.程序源代码:#include"stdio-h"main(){printf("HelloC-world!\n");printf("printf("*\n");printf("*\n");printf("****\n");}【程序7】题目:输出特殊图案,请在c环境中运行,看ー看,VeryBeautiful!.程序分析:字符共有256个。不同字符,图形不ー•样。.程序源代码:#include"stdio.h"main()(chara=176,b=219;printf("%c%c%c%c%c\n",b,a,a,a,b);printf(M%c%c%c%c%c\n'\a,b,a,b,a);printf("%c%c%c%c%c\n,',a,a,b,a,a);printf(M%c%c%c%c%c\n",a,b,a,b,a);printf(M%c%c%c%c%c\n,',b,a,a,a,b);)【程序8】题目:输出9*9口诀。.程序分析:分行与列考虑,共9行9列,i控制行,j控制列。.程序源代码:#include"stdio.h"main()(intij,result;printf("\n");for(i=l;i<10;i++)1forG=l;j<10;j++)(result=i*j;printf(',%d*%d=%-3d",i,j,result);/*-3d表示左对齐,占3位・/)printf("\n");/・每一行后换行・/【程序9】题目:要求输出国际象棋棋盘。.程序分析:用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格。.程序源代码:#include"stdio.h"main()(intij;for(i=0;i<8;i++)Ifor(j=0;j<8;j++)if((i+j)%2==0)printf(M%c%c",219,219);elseprintfCH);printf(,,\n");题目:打印楼梯,同时在楼梯上方打印两个笑脸。.程序分析:用i控制行,j來控制列,j根据i的变化来控制输出黑方格的个数。.程序源代码:#include"stdio.h"main()(intij;printf("\l\l\n");/・输出两个笑脸・/for(i=l;i<ll;i++)(for(j=l;j<=i;j++)priinf("%c%c”,219,219);printfCNT);作者:zhlei812005-1-2211:29回复此发言3回复:经典C源程序100例【程序11]题ロ:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月乂生・对兔子,假如兔子都不死,问每个月的兔子总数为多少?.程序分析:兔子的规律为数列1,123,5,8,13,21…..程序源代码:main()(longfl,f2;inti;fl=f2=l;for(i=l;i<=20;i++){printf("%121d%121d,,,fl,f2);if(i%2=0)printf(”\n");/*控制输出,每行四个・/fl=fl+f2;/*前两个月加起来赋值给第三个月・/f2=fl+f2;/・前两个月加起来赋值给第三个月・/【程序I2)题ロ:判断101-200之间有多少个素数,并输出所有素数。.程序分析:判断素数的方法:用・个数分别去除2到sqn(这个数),如果能被整除,则表明此数不是素数,反之是素数。.程序源代码:#includc"math.h"main()(intm,i,k,h=O,leap=l;printf("\n");for(m=101;m<=200;m++){k=sqrt(m+l);for(i=2;i<=k;i++)if(m%i==O){leap=O;break;)if(leap){printf("%-4d",in);h-H-;if(h%10==0)printfC'Xn*');)leap=1;)printf("\nThetotalis%d",h);【程序13]题目:打印出所有的“水仙花数'所谓“水仙花数’’是指ー个三位数,其各位数字立方和等于该数本身。例如:153是一个“水仙花数'',因为153=1的三次方+5的三次方+3的三次方..程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。.程序源代码:main()(inti,j,k,n;printf(*"waterflower'numberis:M);for(n=100;n<l000;n++)(i=nハ00;/・分解出百位・/j=nハ。%10;/・分解出十位・/k=n%10;/・分解出个位・/if(i*100+j*10+k==i*i*i+j*j*j+k*k*k)(printf("%・5d"m);))printf("\n");题目:将・个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。程序分析:对n进行分解质因数,应先找到ー个最小的质数k,然后按下述步骤完成:⑴如果这个质数恰等丁n,则说明分解质因数的过程已经结朿,打印出即可。⑵如果nok,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。(3)如果n不能被k整除,则用k+l作为k的值,重复执行第一步。2.程序源代码:/*zhengintisdividedyinshu*/main()(intnJ;printf(M\npleaseinputanumber:\n");scanf("%d”,&n);printf("%dゴ,n);for(i=2;i<=n;i++)(while(n!=i)(if(n%i=0){printf(M%d*",i);n=n/i;)elsebreak;))printf(M%d",n);}【程序15]题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B友示,60分以下的用C表示。.程序分析:(a>b)?a:b这是条件运算符的基本例子。.程序源代码:main()(intscore;chargrade;printf(Mpleaseinputascore\n");scanf(H%dn,&score);grade=score>=90?,A,:(score>=60?"B':'C);printf(M%dbelongsto%cM,score,grade);【程序16]题冃:输入两个正整数m和n,求其最大公约数和最小公倍数。作者:zhlei812005-1-2211:30回复此发言4回复:经典C源程序100例.程序分析:利用辗除法。.程序源代码:main()(inta,b,num1,num2,temp;printf(Mpleaseinputtwonumbers"");scanf("%d,%d",&numl,&num2);if(num1{temp=num1;numl=num2;num2=temp;}a=numl;b=num2;while(b!=0)/・利用辗除法,直到b为〇为止・/(temp=a%b;a=b;b=temp;)printf("gongyueshu:%d\n",a);printf("gongbeishu:%d\n",numI*num2/a);【程序1フ】题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。.程序分析:利用while语句,条件为输入的字符不为「:.程序源代码:#include"stdio.h"main()(chare;intletters=0,space=0,digit=0,others=0;printf("pleaseinputsomecharacters\n");while((c=getchar())!=^')if(c>=,a'&&c<=,z,llc>=,A,&&c<='Z')letters++;elseif(c='')space++;elseif(c>='0,&&c<=,9,)digit++;elseothers++;)printf("allinall:char=%dspace=%ddigit=%dolhers=%d\n",letters,space,digit,others);【程序18]题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是ー个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。.程序分析:关键是计算出每ー项的值..程序源代码:main()(inta,n,count=l;longintsn=0,tn=0;printf(Mpleaseinputaandn\n");scanf("%d,%d”,&a,&n);printf(,'a=%d,n=%d\n,',a,n);while(count<=n)(tn=tn+a;sn=sn+tn;a=a*10;++count;)printf(Ma+aa+...=%ld\n",sn);【程序19]题目:一・个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程找出1000以内的所有完数。.程序分析:请参照程序〈一・上页程序14..程序源代码:main()staticintk|10];inti,j,n,s;for(j=2^j<1000;j++)(n=-l;s=j;for(i=l;i!if((j%i)==O){n++;s=s-i;k[n]=i;))if(s=O)!printf(M%disawanshuQ);for(i=0;iprintf("%d;;k[i]);printf(M%d\n\k[n]);【程序20]题目:ー球从100米高度白由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?.程序分析:见下面注释.程序源代码:main()(floatsn=IOO.O,hn=sn/2;intn;for(n=2;n<=!〇;n++)(sn=sn+2*hn;/*第n次落地时共经过的米数・/hn=hn/2;/*第n次反跳高度・/)printf("thetotalofroadis%f\n",sn);printf("thetenthis%fmeter\n",hn);)【程序21]题目:猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩Fー个桃子了。求第一天共摘了多少。.程序分析:采取逆向思维的方法,从后往前推断。.程序源代码:main()(intday,xl,x2;day=9;x2=l;while(day>O){xl=(x2+l)*2;/*第一天的桃子数是第2天桃子数加1后的2倍・/x2=xl;day—;)printf("thetotalis%d\n'\xl);【程序22]题目:两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。己抽签决定比赛名单。有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。.程序分析:判断素数的方法:用ー个数分别去除2到sqn(这个数),如果能被整除,则表明此数不是素数,反之是素数。.程序源代码:main()(chari.j,k;/*i是a的对手,j是b的对手,k是c的对手・/for(i='x,;i<=,z';i++)for(j='x';j<=,z,;j++)(if(i!=j)for(k='x';k<=*z';k++){if(i!=k&&j!=k){if(i!='x'&&k!=x,&&k!=,z,)printf("orderisa-%c\tb-%c\tc-%c\n"jj,k);【程序23]题目:打印出如下图案(菱形)**********************.程序分析:先把图形分成两部分来看待,前四行ー个规律,后三行ー个规律,利用双重for循环,第一层控制行,第二层控制列。.程序源代码:main()(intij,k;for(i=0;i<=3;i++)(for(j=0;j<=2-i;j++)prinlf("H);for(k=0;k<=2*i;k++)prinlf(n*M);printf("\n");)for(i=0;i<=2;i++)(for(j=0;j<=i;j++)printf(HM);for(k=0:k<=4-2*i;k++)printf(H*M);printf(,'\nH);【程序24]题目:有一分数序列:2/1,3/2,5/3,8/5,13/8,2レ13...求出这个数列的前20项之和。.程序分析:请抓住分子与分母的变化规律。.程序源代码:main()(intn,t.number=20;floata=2,b=l,s=0;for(n=1;n<=number;n++)(s=s+a/b;t=a;a=a+b;b=t;/・这部分是程序的关键,请读者猜猜t的作用・/)printf("sumis%9.6f\n",s);【程序25]题目:求1+2!+3!+...+20!的和.程序分析:此程序只是把累加变成了累乘。.程序源代码:main()(floatn,s=O,t=1;for(n=1;n<=20;n++)(t*=n;s+=t;}printf("l+2!+3!...+20!=%e\n';s);【程序26]题冃:利用递归方法求5!。.程序分析:递归公式:fn=fn_l*4!.程序源代码:#includer,stdio.h"main()(inti;intfact();for(i=0;i<5;i++)printf(H\40:%d!=%d\n'\i,fact(i));1intfact(j)intj;{intsum;if(j=O)sum=l;elsesum=j*fact(j-l);returnsum;【程序27]题目:利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。.程序分析:.程序源代码:#include"stdio.h"main()inti=5;voidpalin(intn);printf("\40:,,);palin(i);printfCXn1');}voidpalin(n)intn;{charnext;if(n<=l)(next=getchar();printf(M\n\0:M);pulchar(next);)else(next=getchar();palin(n-l);putchar(next);【程序28]题目:有5个人坐在ー起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,乂说比第2人大两岁。问第2个人,说比第个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大?.程序分析:利用递归的方法,递归分为回推和递推两个阶段。要想知道第五个人岁数,需知道第四人的岁数,依次类推,推到第一人(10岁),再往回推。.程序源代码:age(n)intn;(intc;if(n=l)c=10;elsec=age(n-1)+2;retum(c);)main(){printf("%d”,age⑸);【程序29]题目:给・个不多于5位的正整数,要求:ー、求它是儿位数,二、逆序打印出各位数字。.程序分析:学会分解出每•位数,如下解释:(这里是种简单的算法,师专数002班赵鑫提供).程序源代码:main()longa,b,c,d,e,x;scanf(H%ld",&x);a=xハ000〇;/・分解出方位・/b=x%10000/1000;/・分解出千位・/c=x%1000ハ00;/・分解出百位・/d=x%100”〇;/・分解出十位・/e=x%10;/・分解出个位*/if(a!=0)printf("thereare5,%Id%ld%Id%Id%ld\n”,e,d,c,b,a);elseif(b!=0)printf("thereare4,%ld%Id%Id%ld\n”,e,d,c,b);elseif(c!=0)printf(Mthereare3,%ld%Id%ld\n”,e,d,c);elseif(d!=0)printf("thereare2,%Id%ld\n",e,d);elseif(e!=0)printf(Htherearel,%ld\n",e);【程序30]题目:•个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。.程序分析:同29例.程序源代码:main()(longge,shi,qian,wan,x;scanf(H%ld",&x);wan=x/10000;qian=x%10000/1000;shi=x%100/10;ge=x%10;if(ge=wan&&shiニニqian)/・个位等于万位并且十位等于千位・/printf(Mthisnumberisahuiwen\n");elseprintf("thisnumberisnotahuiwen\nM);)【程序31]题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母ー样,则继续判断第二个字母。.程序分析:用情况语句比较好,如果第•个字母•样,则判断用情况语句或if语句判断第二个字母。.程序源代码:#includevoidmain()charletter;printf("pleaseinputthefirstletterofsomeday\n");while((letter=getch())!=Y)/・当所按字母为Y时オ结束・/{switch(letter){case'S':printf(''pleaseinputsecondletter\n");if((letter=getch())='a')printf("saturday\n");elseif((lettei^getch())="u')printf("sunday\n");elseprintf("dataerror\n");break;case'F':printf("friday\n");break;case'M':printf("monday\n");break;case'T':printf("pleaseinputsecondletter\n");if((letter=getch())=,u,)printf("tuesday\n");elseif((letter=getch())="h')printf("thursday\n");elseprintf("dataerror\n");break;case'W':printf("wednesday\n");break;default:printf("dataerror\n");)【程序32]题目:Pressanykeytochangecolor,doyouwanttotryit.Pleasehurryup!.程序分析:.程序源代码:#includevoidmain(void)(intcolor;for(color=0;color<8;color++)(textbackground(color);/*设置文本的背景颜色・/cprintf("Thisiscolor%d\r\n",color);cprintf("Pressanykeytocontinue\An");getch();/・输入字符看不见ッ【程序33]题目:学习gotoxy()与clrscr()函数.程序分析:.程序源代码:#includevoidmain(void){clrscrO;/・清屏函数・/textbackground(2);gotoxy(l,5)ソ*定位函数・/cprintf(nOutputatrow5columnl\n");textbackground(3);gotoxy(20,10);cprintf("Oulputatrow10column20\n");【程序34]题冃:练习函数调用.程序分析:.程序源代码:#includevoidhello_world(void)(printf("Hello,world!\n");)voidthree_hellos(void)(intcounter;for(counter=1;counter<=3;counter++)hello_world();/・调用此函数・/)voidmain(void)threc_hellos();/・调用此函数・/【程序35]题目:文本颜色设置.程序分析:.程序源代码:#includevoidmain(void)intcolor;for(color=1;color<16;color++)textcolor(color);/*设置文本颜色・/cprintf("Thisiscolor%d\r\n",color);)textcolor(128+15);cprintf(MThisisblinking\r\nH);【程序36]题冃:求100之内的素数.程序分析:.程序源代码:#include#include"math.h"#defineN101main(){intij,line,a[N];for(i=2;ifor(i=2;ifor(j=i+l;j{if(a[i]!=O&&a|j]!=O)if(a[jl%a[i]=O)a|j]=O;)printf(',\nH);for(i=2,line=0;i{if(a[i]!=0){printf(・%5d”,a[il);line++;Jif(line==I0){printf("\n");line=O;J)【程序37]题冃:对10个数进行排序.程序分析:可以利用选择法,即从后9个比较过程屮,选择一个最小的与第一个元素交换,下次类推,即用第二个元素与后8个进行比较,并进行交换。.程序源代码:#defineN10main(){inti,j,min,tem,a[N];/♦inputdata*/printf("pleaseinputtennum:\n");for(i=0;i{printf("a|%d|=",i);scanf(H%d'\&a|i]);)printf("\n");for(i=0;iprintf("%5d”Hi]);printf(M\n");/*sorttennum*/fbr(i=O;i{min=i;fbr(j=i+l;jif(a[min]>a[j])min=j;tem=a[i];a[i]=a[min];a[min]=tem;)/♦outputdata*/printf("Aftersorted\nH);fdr(i=0;iprintf(M%5dM,a[i]);【程序38]题目:求一个3*3矩阵对角线元素之和.程序分析:利用双重for循环控制输入二维数组,再将累加后输出。.程序源代码:main()(floata[3][3],sum=0;inti,j;prints"pleaseinputrectangleelement:\n");for(i=0;i<3;i++)for(j=0;j<3;j++)scanf("%r,&a[i][j]);for(i=0;i<3;i++)sum=sum+a[i][i];printf("duijiaoxianheis%6.2f\sum);【程序39]题目:有一个已经排好序的数组。现输入ー个数,要求按原来的规律将它插入数组中。.程序分析:首先判断此数是否大于最后ー个数,然后再考虑插入中间的数的情况,插入后此元素之后的数,依次后移ー个位置。.程序源代码:main(){inta[ll]={1,4,6,9,13,16,19,28,40,100);inttempl,temp2,number.end,i,j;printf("originalarrayis:\nH);for(i=0;i<10;i++)printf("%5d';a|i]);printf("\nH);printf("insertanewnumber:");scanf("%d",&number);end=a[9J;if(number>end)a|10]=number;else{for(i=0;i<10;i++){if(a[i]>number)

{templ=a[i];a[i]=number;fbr(j=i+l;j<ll;j-H-)(temp2=a|jl;a[j]=templ;templ=temp2;)break;for(i=0;i<ll;i++)printf("%6d",a[i]);【程序40]题目:将一个数组逆序输出。.程序分析:用第一个与最后ー个交换。.程序源代码:#defineN5main()(inta[NJ={9,6,5,4,l}J,temp;printf("\noriginalarray:\n");for(i=0;iprintf("%4d",a[i]);for(i=0;i{temp=a[i];a[i]=a[N-i-l];a[N-i-l]=temp;}printf("\nsortedarray:\n");for(i=0;iprintf("%4d",a[i]);)【程序41]题目:学习static定义静态变量的用法.程序分析:.程序源代码:#include"stdio.h"varfunc()(intvar=O;staticintstatic_var=O;printf("\40:varequal%d\nH,var);printf("\40:staticvarequal%d\n",static_var);printf("\n");var++;static_var++;}voidmain(){inti;fdr(i=O;i<3;i++)varfunc();【程序42]题目:学习使用auto定义变量的用法.程序分析:.程序源代码:#include"stdio.h"main(){inti,num;num=2;for(i=0;i<3;i-H-){printf("\4O:Thenumequal%d\n",num);num++;{autointnum=l;printf("\40:Theinternalblocknumequal%d\n”,num);num++;}})【程序43]题目:学习使用static的另ー用法。.程序分析:.程序源代码:#include"stdio.h"main()inti,num;num=2;for(i=0;i<3;i++)(printf("\40:Thenumequal%d\n*',num);num++;(staticintnum=l;printf("\40:Theinternalblocknumequal%d\n",num);num++;【程序44]题冃:学习使用external的用法。.程序分析:.程序源代码:#include"stdio.h"inta.b,c;voidadd(){inta;a=3;c=a+b;1voidmain(){a=b=4;add();printf("Thevalueofcisequalto%d\n",c);)【程序45]题目:学习使用register定义变量的方法。.程序分析:.程序源代码:voidmain(){registerinti;inttmp=O;for(i=l;i<=100;i++)tmp+=i;printfC'Thesumis%d\n",tmp);【程序46]题目:宏#define命令练习(1).程序分析:.程序源代码:#include"stdio.h"#defineTRUE1#defineFALSE0#dcfineSQ(x)(x)*(x)voidmain(){intnum;intagain=l;printf("\40:Programwillstopifinputvaluelessthan5O.\n");while(again){printf("\40:Pleaseinputnumber==>M);scanf("%d”,&num);printf("\40:Thesquareforthisnumberis%d\n",SQ(num));if(num>=50)again二TRUE;elseagain=FALSE;【程序47]题目:宏#define命令练习(2)L程序分析:2.程序源代码:#include"stdio.h"#defineexchange(ab)いノ・宏定义中允许包含两道衣裳命令的情形,此时必须在最右边加上へ*/intt;\t=a;\a=b;\b=t;\)voidmain(void)(intx=10;inty=20;printf(Hx=%d;y=%d\n"xy);exchange(x,y);printf("x=%d;y=%d\n"エ,y);【程序48]题冃:宏#define命令练习(3).程序分析:.程序源代码:#defineLAG>#defineSMA<#dcfincEQ==#include"stdio.h"voidmain(){inti=10;intj=20;if(iLAGj)printf("\40:%dlargerthan%delseif(iEQj)printf("\40:%dequalto%delseif(iSMAj)printf("\40:%dsmallerthan%d\n",ij);elseprintf("\40:Nosuchvalue.\nM);【程序49]题目:#if#ifdef和#ifndef的综合应用。.程序分析:.程序源代码:#include"stdio.h"#defineMAX#defineMAXIMUM(x,y)(x>y)?x:y#defineMINIMUM(x,y)(x>y)?y:xvoidmain(){inta=10,b=20;#ifdefMAXprintf("\40:Thelargeroneis%d\n”,MAXIMUMS,b));#elseprintf("\40:Theloweroneis%d\n",MINIMUM(a,b));#endif#ifndefMINprintf("\40:Theloweroneis%d\n',MINIMUM(a,b));#elseprintf("\40:Thelargeroneis%d\nn,MAXIMUM(a,b));#endif#undefMAX#ifdefMAXprintf("\40:Thelargeroneis%d\n,\MAXIMUM(a,b));#elseprintf("\40:Theloweroneis%d\n',MINIMUM(a,b));#endif#defineMIN#ifndefMINprintf("\40:Theloweroneis%d\n',MINIMUM(a,b));#elseprintf("\40:Thelargeroneis%d\n”,MAXIMUM(a,b));#endif【程序50]题冃:#include的应用练习.程序分析:.程序源代码:test.h文件如下:#defineLAG>#defineSMA<#defineEQ==#include"test.h"/*ー个新文件50.c»包含test.h*/#include"stdio.hHvoidmain(){inti=10;intj=20;if(iLAGj)printf("\40:%dlargerthan%d\n",i,j);elseif(iEQj)printf("\40:%dequalto%d\n",ij);elseif(iSMAj)printf("\40:%dsmallerthan%d\n",ij);elseprintf("\40:NosuchvalueAn");)【程序51]题目:学习使用按位与&。.程序分析:0&0=0;0&l=0;1&0=0;1&1=1.程序源代码:#include"stdio.h"main()(inta,b;a=077;b=a&3;printf("\40:Thea&b(decimal)is%d\n",b);b&=7;printf("\40:Thea&b(dccimal)is%d\n",b);)【程序52]题目:学习使用按位或I。.程序分析:010=0;011=1;110=1;111=1.程序源代码:#include"stdio.h"main()(inta,b;a=077;b=al3;printf("\40:Thea&b(decimal)is%d\n",b);bl=7;printf("\40:Thea&b(decimai)is%d\n",b);【程序53]题冃:学习使用按位异或八..程序分析:0Ao=0;0Al=1;lA0=l;lAl=0.程序源代码:#include"stdio.h*'main()(inta,b;a=077;b=aA3;printf("\40:Thea&b(decimal)is%d\n",b);bA=7;printf("\40:Thea&b(decimal)is%d\n",b);【程序54]题目:取一个整数a从右端开始的4〜7位。程序分析:可以这样考虑:⑴先使a右移4位。(2)设置ー个低4位全为1,其余全为〇的数。可用~(~〇<<4)(3)将上面二者进行&运算・.程序源代码:main()unsigneda,b,c,d;scanf(”%〇”,&a);b=a»4;c=一(〜〇«4);d=b&c;printf("%o\n%o\n",a,d);【程序55]题冃:学习使用按位取反~。.程序分析:〜0=1;〜1=0;.程序源代码:#include"stdio.h"main(){inta,b;a=234;b=~a;printf("\40:Thea*s1complement(decimal)is%d\n*',b);a=-a;printf("\40:Thea's1complement(hexidecimal)is%x\n",a);【程序56]题目:画图,学用circle画圆形。.程序分析:.程序源代码:/♦circle*/#include"graphics.-main(){intdriver,mode,i;floatj=l,k=1;drivei^VGA;mode=VGAHI;initgraph(&driver,&mode,"");setbkcolor(YELLOW);for(i=0;i<=25;i++){setcolor(8);circle。10,250,k);k=k+j;j=j+0.3;【程序57]题冃:画图,学用line画直线。.程序分析:.程序源代码:#include"graphics.h"main(){intdriver,modej;floatxO,yO,yl,xl;floatj=12,k;driver=VGA;mode=VGAHI;initgraph(&driver,&mode,"H);setbkcolor(GREEN);x()=263;y0=263;yl=275;x1=275;for(i=0;i<=18;i-H-){setcolor(5);line(xO,yO,xO,yl);x0=x0-5;y0=y0-5;xl=xl+5;yl=yl+5;j=j+10;)x0=263;yl=275;y0=263;for(i=();i<=20;i++)(setcolor(5);line(xO,yO,xO,yl);x0=x0+5;y0=y0+5;yl=yl-5;【程序58]题目:画图,学用rectangle画方形。.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。.程序源代码:#include"graphics.h"main(){intx0,y0,yl,xl,driver,mode,i;driver=VGA;mode=VGAHI;initgraph(&driver,&mode,"");setbkcolor(YELLOW);x0=263;y0=263;yl=275;x1=275;fdr(i=0;i<=18;i++)(setcolor(1);rectangle(xO,yO,xl,yl);xO=xO-5;yO=yO-5;xl=xl+5;yl=yl+5;)settextstyle(DEFAULT_FONTHORIZ_DIR,2);outtexlxy(150,40,"Howbeautifulitis!");lined30,60,480,60);setcok)K2);circle(269,269,137);【程序59]题目:画图,综合例子。.程序分析:.程序源代码:definePAI3.1415926defineB0.809include"graphics.—#include"math.h"main()(inti,j,k,xO,yO,x,y,driver.mode;floata;driver=CGA;mode=CGACO;initgraph(&driver,&mode,"");setcolor(3);setbkcolor(GREEN):x0=150;y0=100;circle(x0,y0,10);circle(x0,y0,20);circle(x0,y0,50);for(i=0;ivl6;i++)(a=(2*PAI/16)*i;x=ceil(xO+48*cos(a));y=ceil(yO+48*sin(a)*B);setcolor(2);line(x0,y0,x,y);)setcolor(3);circle(x0,y0,60);/*Make0timenormalsizeletters*/settextstyle(DEFAULT_FONT,HORIZ_DIR,0);outtextxy(10,170,Mpressakey");getch();setfillstyle(HATCH_FILL,YELLOW);floodfill(202,l00.WHITE);getch();for(k=0;k<=500;k++)(setcolor(3);for(i=0;i<=16;i-H-)(a=(2*PAI/16)*i+(2*PAI/180)*k;x=ceil(x(>+-48*cos(a));y=ceil(y(>4-48+sin(a)*B);setcolor(2);line(xO,yO,x,y);(for(j=l;j<=50;j++)(a=(2*PAI/l6)*i+(2*PAI/l80)*k-l;x=ceil(xOi-48*cos(a));y=ceil(yO+48*sin(a)*B);line(xO,yO,x,y);)1restorecrtmodeO;【程序60]题目:画图,综合例子。.程序分析:.程序源代码:#include"graphics.h"defineLEFT0defineTOP0defineRIGHT639defineBOTTOM479defineLINES400defineMAXCOLOR15main()(intdriver.mode,error;intxl,y1;intx2,y2;intdx1,dyLdx2,dy2j=l;intcount=0;intcolor=0;driver=VGA;mode=VGAHI;initgraph(&driver,&mode,,M,);xl=x2=yl=y2=10;dxl=dyl=2;dx2=dy2=3;while(!kbhit()){Iine(xl,yl,x2,y2);xI+=dx1;yl+=dy1;x2+=dx2;y2+dy2;if(xl<=LEFTIx1>=RIGHT)dxl=-dxl;if(yl<=TOPIIyl>=BOTTOM)dyl=-dyl;if(x2<=LEFTIIx2>=RIGHT)dx2=-dx2;if(y2<=TOPIIy2>=BOTTOM)dy2=-dy2;if(++count>LINES)(setcolor(color);color=(color>=MAXCOLOR)?0:++color;))closegraph();)【程序61]题目:打印出杨辉三角形(要求打印出10行如下图)1.程序分析:1112113311464115101051.程序源代码:main(){intij;inta[10][10]:printf("\nH);for(i=0;i<10;i-H-){a[i][O]=l;a[i][i]=l;)for(i=2;i<10;i++)for(j=l;ja[i]U]=a[i-l][j-l]+a[i-l]U];for(i=0;i<10;i++){for(j=0;j<=i;j++)printf(T,a[i皿);printf("\n");【程序62]题目:学习putpixel画点。.程序分析:.程序源代码:#include"stdio.h"#include"graphics.h"main(){inti,j,driver=VGA,mode=VGAHI;initgraph(&driver,&mode/M,);setbkcolor(YELLOW);for(i=50;i<=230;i+=20)for(j=5();j<=230;j-H-)putpixel(ijj);for(j=50;j<=230;j+=20)forCi=50;i<=230;i++)putpixel(ij,l);)【程序63]题目:画椭圆ellipse.程序分析:.程序源代码:#include"stdio.hn#include"graphics.h"#includeMconio.h"main(){intx=360,y=160,driver=VGA,mode=VGAHI;intnum=20,i;inttop,bottom;initgraph(&driver,&mode,"");top=y-30;bottom=y-30;for(i=O;i{ellipse(250,25070,360,top,bottom);top-=5;bottom+=5;)getch();【程序64]题ロ:利用ellipseandrectangle画图〇.程序分析:.程序源代码:#include"stdio.h"#include"graphics.—#include"conio.h"main(){intdriver=VGA,mode=VGAHI;inti,num=15,top=50;intleft=2O,right=5O;initgraph(&driver,&mode,"");for(i=0;i{ellipse(250,250,0,36(),right,left);ellipse(250,250,0,360,20,top);rectangle(20-2*i,20-2*i,l0*(i+2)J0*(i+2));right+=5;left+=5;top+=10;)getch();【程序65]题目:ー个最优美的图案。.程序分析:.程序源代码:#include"graphics-h'1#include"math.h"#include"dos.h"#include"conio.h"#include"stdlib.h"#include"stdio.h"#includeMstdarg.hM#defineMAXPTS15#dcfinePI3.1415926structPTS{intx,y;};doubleAspectRatio=0.85;voidLinelbDemo(void)(structviewporttypevp;structPTSpoints[MAXPTS];inti,j,h,w,xcenter,ycenter;intradius,angle,step;doublerads;printf("Movelb/LinelbDemonstration");getviewsettings(&vp);h=vp.bottom-vp.top;w=vp.right-vp.left;xcenter=w/2;/*Determinethecenterofcircle*/ycenter=h/2;radius=(h-30)/(AspectRatio*2);step=360/MAXPTS:/*Determine#ofincrements*/angle=0;/*Beginatzerodegrees*/for(i=0;irads=(double)angle*PI/180.0;/♦Convertangletoradians*/points[i].x=xcenter+(int)(cos(rads)*radius);points[i].y=ycenter-(int)(sin(rads)*radius*AspectRatio);angle+=step;/*Movetonextincrement*/)circle(xcenter,ycenter,radius);/*Drawboundingcircle*/fbr(i=0;ifbr(j=i;jmoveto(points[i].x,points[i].y);/*Movetobeginningofcord*/lineto(points|j].x,points[j].y);/*Drawthecord*/}I}main(){intdriver,mode;driver=CGA;mode=CGAC0;initgraph(&driver,&mode,"");setcolor(3);setbkcolor(GREEN);LinelbDemo();}【程序66]题目:输入3个数ahc,按大小顺序输出。.程序分析:利用指针方法。.程序源代码:/*pointer*/main()(intnl,n2,n3;int*pointerl,*pointer2,*pointer3;printf("pleaseinput3number:n1,n2,n3scanf("%d,%d,%d”,&nL&n2,&n3);pointerl=&nl;pointer2=&n2;pointer3=&n3;if(nl>n2)swap(pointerl,pointer2);if(nl>n3)swap(pointer1,pointer3);if(n2>n3)swap(pointer2,pointer3);printf("thesortednumbersare:%d,%d,%d\n",n1,n2,n3);)swap(pl,p2)int*pl,*p2;{intp;p=*pI;*pl=*p2;*p2=p;【程序671题目:输入数组,最大的与第一个元素交换,最小的与最后ー个元素交换,输出数组。1.程序分析:谭浩强的书中答案有问题。2.程序源代码:main(){intnumber[10];input(number);max_min(number);output(number);input(number)intnumber!10];{inti;for(i=0;i<9;i++)scanf("%d,",&number[i]);scanf(H%d",&number|9]);)max_min(array)intarray[10];{int*max,*min,k,l;int*p,*arr_end;arr_end=array+10;max=min=array;fbr(p=aiTay+l;pif(*p>*max)max=p;elseif(*p<*min)min=p;k=*max;l=*min;♦p=array[O];array[O]=l;l=*p;*p=array|9];array[9|=k;k=*p;return;!output(array)intarray[10];{int*p;for(p=array;pprintf("%d,",*p);printf("%d\n",array[9|);【程序68]题目:有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数1.程序分析:.程序源代码:main()(intnumber[20],n,m,i;printff'thetotalnumbersis:");scanf("%d",&n);printf("backm:");scanf("%d",&m);for(i=0;iscanf("%d,",&number[i]);scanf("%d",&number[n-l]);move(number,n,m);for(i=0;iprintf("%d,",number[i]);printf("%d",number[n-lJ);)move(array,n,m)intn,m,array[20];(int*p,array_end;array_end=*(array+n-1);fbr(p=array+n-l;p>array;p-)*p=*(p-l);*array=array_end;m--;if(m>0)move(array,n,m);【程序69]题冃:有n个人围成一・圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。.程序分析:.程序源代码:#definenmax50main()(inti,k,m,n,num[nmax],*p;printfif"pleaseinputthetotalofnumbers:");scanf("%d",&n);p=num;for(i=0;i*(p+i)=i+l;i=0;k=0;m=0;while(m{if(*(p+i)!=O)k++;if(k=3){*(p+i)=0;k=0;m++;)i++;if(i==n)i=0;)while(*p==0)p++;printf("%disleft\n",*p);)【程序70]题目:写・个函数,求•个字符串的长度,在main函数中输入字符串,并输出其长度。.程序分析:.程序源代码:main(){intlen;char*str[20|;printf("pleaseinputastring:\n");scanf("%s",str);len=length(str);printff'thestringhas%dcharacters."Jen);length(p)char*p;(intn;n=0;while(*p!二、〇')(n++;p++;)returnn;I【程序フ1】题冃:编写input。和outpuK)函数输入,输出5个学生的数据记录。1.程序分析:.程序源代码:#defineN5structstudent{charnum|6);charname[8];intscore|4|;}stu[N];input(stu)structstudentstu[];{inti,j;for(i=();i{printf("\npleaseinput%dof%d\n”.i+l,N);printf("num:");scanf("%s",stu[i].num);printf("name:H);scanf("%s",stu[i].name);for(j=0;j<3;j++){printf("score%d.",j+l);scanf(H%d'\&stu[i].score[j]);)printf("\n");)}print(stu)structstudentstu|];{inti,j;printf("\nNo.NameScolSco2Sco3\n");for(i=0;i{printf("%-6s%-1Osr\stu[i].num,stu[i].name);for(j=0;j<3;j++)printf("%-8d,\stu[i].score[j]);main(){input();pnnt();【程序72]题目:创建一个链表。.程序分析:.程序源代码:/*creatalist*/#include"stdlib.h"#include"stdio.h"structlist{intdata:structlist*next;};typedefstructlistnode;typedefnode*link;voidmain(){linkptnhead;intnumj;ptr=(link)malloc(sizeof(node));ptr=head;printf("pleaseinput5numbers==>\n");for(i=0;i<=4;i++)(scanf(H%d",&num);ptr->data=num;ptr->next=(link)malloc(sizeof(node));if(i==4)ptr->next=NULL;elseptr=ptr->next;)ptr=head;while(ptr!=NULL){printf("Thevalueis==>%d\n",ptr->data);ptr=ptr->next;【程序73]题目:反向输出•个链表。.程序分析:.程序源代码:/*reverseoutputalist*/#include"stdlib.h"#include,,stdio.hHstructlist{intdata;structlist*next;};typedefstructlistnode;typedefnode*link;voidmain(){linkptr,head,tail;intnumj;tail=(link)malloc(sizeof(node));tail->next=NULL;ptr=tail;printf("\npleaseinput5data=>\n");fbr(i=O;i<=4;i++)(scanf("%d'\&num);ptr->data=num;head=(link)malloc(sizeof(node));head->next=ptr;ptr=head;!ptr=ptr->next;while(ptr!=NULL){printf("Thevalueis==>%d\n",ptr->data);ptr=ptr->next;})【程序74]题目:连接两个链表。.程序分析:.程序源代码:#include"stdlib.h"#include,'stdio.h^^structlist{intdata;structlist*next;typedefstructlistnode;typedefnode*link;linkdelete_node(linkpointerjinktmp){if(tmp==NULL)/*deletefirstnode*/returnpointer->next;else{if(tmp->next->next==NULL)/*deletelastnode*/tmp->next二NULL;else/*delctetheothernode*/tmp->next=tmp->next->next;returnpointer;)}voidselection_sort(linkpointer,intnum){linktmp,btmp;inti,min;for(i=0;i{tmp=pointer;min=tmp->data;btmp=NULL;while(tmp->next){if(min>tmp->next->data){min=tmp->next->data;btmp=tmp;)tmp=tmp->next;1printf("\40:%d\nM,min);pointer=delete_node(pointer,btmp);))linkcreate_list(intarray[],intnum)(linktmp1,tmp2,pointer;inti;pointer=(link)malloc(sizeof(node));pointer->data=array[0];tmpl=pointer;fbr(i=l;i(tmp2=(link)malloc(sizeof(node));tmp2->next=NULL;tmp2->data=array[i];tmpl->next=tmp2;tmpl=tmpl->next;)returnpointer;linkconcatenate(linkpointeri,linkpointer2){linktmp;tmp=pointerl;while(tmp->next)tmp=tmp->nexl;tmp->next=pointer2;returnpointer1;)voidmain(vo

温馨提示

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

评论

0/150

提交评论