复件+C语言编程经典100例.pdf
《复件+C语言编程经典100例.pdf》由会员分享,可在线阅读,更多相关《复件+C语言编程经典100例.pdf(91页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、C语言经典编程100例程序1】题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?1.程序分析:兔子的规律为数列1,12 3,5,8,13,2 1.2.程序源代码:m a i n()l o n g f l,f 2;i n t i;f l=f 2=l;f o r(i=l;i =2 0;i+)p r i n t f C%12 1d%12 1d;f l,f 2);i f(i%2=0)控制输出,每行四个*/f l=f l+/*前两个月加起来赋值给第三个月*/f 2=f l +f 2;/*前两个月加起来赋值给
2、第三个月*/)【程序2】题目:判断101-2 00之间有多少个素数,并输出所有素数。1.程序分析:判断素数的方法:用一个数分别去除2到s q r t(这个数),如果能被整除,则表明此数不是素数,反之是素数。2.程序源代码:#i n c l ude m a t h.hm a i n()(i n t m,i,k,h=0,l c a p=l;p r i n t f CX 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,m);h+;if(h%10=0)printf(
3、nn);)leap=1;)printf(nThe total is%dn,h);【程序3】题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。2.程序源代码:main()(int i,j,k,n;printf(water flowefnumber is:n);for(n=100;n 1000;n+)i=n/100;/*分解出百位*/j=n/10%10;/*分解出十位*/k=n%10;/*分解出
4、个位*/if(i*100+j*10+k=i*i*i+j*j*j+k*k*k)printf(n%-5dH,n);)1printfCKn1);)【程序4】题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。如果n k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。如 果n不能被k整除,则用k+1作为k的值,重复执行第一步。2.程序源代码:/*z he n g i n t i s di vi
5、 de d y i n s hu*/m a i n()(i n t n,i;p r i n t f (/z n p l e a s e i n p ut a n um b e r:n/z);scanf&n);p r i n t f (,%d=z,,n);f o r(i=2;i=90分的同学用A表示,6 0-89分之间的用B衣示,6 0分以卜的用C表示。1.程序分析:(a b)?a:b这是条件运算符的基本例子。2 .程序源代码:m a i n()(i n t s c o r e;c ha r g r a de;p r i n t f(p l e a s e i n p ut a s c o r
6、e n);scanf&score);g r a de=s c o r e=90?A :(s c o r e=6 0?B :C);p r i n t f (z,%d b e l o n g s t o 枇 ,s c o r e,g r a de);)【程序6】题目:输入两个正整数m和n,求其最大公约数和最小公倍数。1.程序分析:利用辗除法。2.程序源代码:m a i n()i n t a,b,n um l,n um 2,t e m p;p r i n t f (,zp l e a s e i n p ut t w o n um b e r s:X n );s c a n f (绘d,%d”,&n
7、 um l,&n um 2);i f(n um l t e m p=n um l;n um l=n um 2;n um 2=t e m p;a=n um l;b=n um 2;w hi l e(b!=0)/*利用辗除法,直到b为0为止*/(t e m p=a%b;a=b;b=t e m p;p r i n t f (/zg o n g y ue s hu:%d n,z,a);p r i n t f (,zg o n g b e i s hu:%c i nz/,n um l*n um 2/a);)【程序7】题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。1.程序分析:利用
8、w h i l e语句,条件为输入的字符不为 n .2.程序源代码:#i n c l u d e “s t d i o.h m ai n ()c h ar c;i n t l e t t e rs=0,s p ac e=0,d i g i t=0,o t h e rs=0;p ri n t f (,zp l e as e i n p u t s o m e c h arac t e rs、。”);w h i l e (c=g e t c h ar()!=n )i f (c=,a&c 二-L|c 二 A&c=O&c 二 9)d i g i t+;e l s eo t h e rs+;)p ri
9、n t f (/zal l i n al 1:c h ar=%d s p ac e=%d d i g i t二%d o t h e rs=%d n”,l e t t e rs,s p ac e,d i g i t,o t h e rs);)【程序8】题目:求 s=a+aa+aaa+aaaa+aa.a 的值,其中 a 是一个数字。例如 2+22+222+2222+22222(此时共有5个数相加),儿个数相加有键盘控制。1.程序分析:关键是计算出每一项的值。2.程序源代码:m ai n()(i n t a,n,c o u n t=l;l o n g i n t s n=0,t n=0;p ri n
10、 t f (p l e as e i n p u t a an d n n);s c an f (绘d,%d,&a,&n);p ri n t f (a=%d,n=%d n,a,n);w h i l e(c o u n t=n)t n=t n+a;s n=s n+t n;a=a*10;+c o u n t;)p ri n t f (a+aa+.=%d n”,s n);)【程序9】题目:个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程找出1000以内的所有完数。1.程序分析:请参照程序 一上页程序14.2.程序源代码:m ai n O(s t at i c i n t
11、k 10;i n t i,j,n,s;f o r(j=2;j 1000;j+)(n=-l;s=j;f o r(i=l;i i f(j%i)=O)(n+;s=s-i;k n =i:)i f(s=O)p ri n t f (,z%d i s a w an s h u”,j);f o r(i=0;i p ri n t f (%d,k i );p ri n t f (d n,k ri );)【程序10题目:球从100米高度自由落下,每次落地后反跳回原高度的半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?1.程序分析:见下面注释2.程序源代码:m ai n()(f l o at s n
12、=100.0,h n=s n/2;i n t n;f o r(n=2;n=10;n+)|s n=s n+2*h n;/*第n次落地时共经过的米数*/h n=h n/2;/*第n次反跳高度*/)p ri n t f (/zt h e t o t al o f ro ad i s s n);p ri n t f (t h e t e n t h i s%f m e t e r n/z,h n);)【程序11题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?1.程序分析:可填在百位、卜位、个位的数字都是1、2、3、4 o组成所有的排列后再去掉不满足条件的排列。2.程序
13、源代码:m ai n ()(i n t i,j,k;p ri n t f(n);f o r(i=l;i 5;i+)/*以下为三重循环*/f o r(j=l;j 5;j+)f o r(k=l;k 5;k+)(i f (i!=k&i!=j&j!=k)/*确保 i、j、k 三位互不相同*/p ri n t f (%d,%d,%d n”,i,j,k);)【程序12题目:企业发放的奖金根据利润提成。利润低于或等于10万元时,奖金可提10%;利涧高了 10万元,低于20万元时,低丁 10万元的部分按10%提成,高于10万元的部分,可可提成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40
14、万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?1.程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。2.程序源代码:m ai n()(l o n g i n t i;i n t b o n u s I,b o n u s 2,b o n u s 4,b o n u s 6,b o n u s 10,b o n u s;s c an f&i);b o n u s 1=100000*0.1;b o n u s 2=b o n u s
15、 1+100000*0.75;b o n u s 4=b o n u s 2+200000*0.5;bonus6=bonus4+200000*0.3;bonus10=bonus6+400000*0.15;if(i=100000)bonus=i*0.1;else if(i=200000)bonus=bonus1+(i-100000)*0.075;else if(i=400000)bonus=bonus2+(i-200000)*0.05;else if(i=600000)bonus=bonus4+(i-400000)*0.03;else if(i=1000000)bonus=bonus6+(i-6
16、00000)*0.015;elsebonus=bonus10+(i-1000000)*0.01;printf(bonus=%d”,bonus);【程序13题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后的结果满足如下条件,即是结果。请看具体分析:2.程序源代码:#include math,h”mainO(long int i,x,y,z;for(i=l;i 2)/*如果是闰年且月份大于2,总天数应该加一天*/sum+;printf(*I t is t
17、he%dth day.”,sum);【程序1 5 题目:输入三个整数x,y,z,请把这三个数由小到大输出。1.程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x y则将x与y的值进行交换,然后再用x与z进行比较,如果x z则将x与z的值进行交换,这样能使x最小。2 .程序源代码:main()(int x,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=t;/*交换 x,z 的值*/if(y z)t=y;y二Z;Z=t;/*交换 Z,y 的值*/printf(z/small
18、 to big:%d%d%d n,x,y,z);)【程序1 6 题目:用*号输出字母C的图案。L程序分析:可先用*号在纸上写出字母C,再分行输出。2.程序源代码:#include“stdio.hmain()(printf(,zH ello C-world!nz,);printf(z/*n);printf(/z*n);printfC *n);printf(z/*n);)【程序1 7 题目:输出特殊图案,清在c环境中运行,看一看,V ery B eautiful!1.程序分析:字符共有2 5 6个。不同字符,图形不样。2 .程序源代码:#include stdio.hmain()(char a=1
19、 7 6,b=2 1 9;printf(*%c%c%c%c%c n?z,b,a,a,a,b);printf(z,%c%c%c%c%c n,z,a,b,a,b,a);printf(*%c%c%c%c%c n*,a,a,b,a,a);printf(z,%c%c%c%c%c n,z,a,b,a,b,a);printf(/z%c%c%c%c%c n/z,b,a,a,a,b);【程序1 8 题目:输出9*9 口诀。1.程序分析:分行与列考虑,共9行9歹!J,i控制行,j控制列。2 .程序源代码:include“stdio.hmain()int i,j,result;printf(n);for(i=l;i
20、 1 0;i+)for(j=l;j 1 0;j+)(result=i*j;printfC%d*%d=%-3 d,;i,j,result);/*-3 d 表示左对齐,占 3 位*/)printf(n);/*每一行后换行*/【程序1 9 题目:耍求输出国际象棋棋盘。】.程序分析:用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格。2 .程序源代码:#include“stdio.hmainO(int i,j;for(i=0;i 8;i+)for(j=0;j 8;j+)if(i+j)%2=0)printf(%c%c”,2 1 9,2 1 9);elseprintf();print
21、f(n);)【程序2 0 题目:打印楼梯,同时在楼梯上方打印两个笑脸。1.程序分析:用i控制行,j来控制列,j根据i的变化来控制输出黑方格的个数。2 .程序源代码:ttinclude stdio.hmain()int i,j;printf(l l n);/*输出两个笑脸*/for(i=l;i ll;i+)(for(j=l;j 0)x l=(x 2+l)*2;/*第一天的桃子数是第2天桃子数加1 后的2 倍*/x 2=x l;day 一;)p r in t f(z/t h e t o t al is%d n”,x l);)【程序2 2 题目:两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,
22、乙队为x,y,z 三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a 说他不和x比,c 说他不和x,z 比,清编程序找出三队赛手的名单。1 .程序分析:判断素数的方法:用一个数分别去除2 到 s q r t (这个数),如果能被整除,则表明此数不是素数,反之是素数。2 .程序源代码:m ain()(ch ar i,j,k;/*i是 a 的对手,j 是b 的对手,k 是 c 的对手*/fo r (i=,x ;i=,z ;i+)fo r(j-x ;j -z ;j+)fo r (k=x ;k =z;k+)if(i!=k&j!=k)if(i!=x&k!=x&k!=z )p r in t f(o r
23、 der is a-%c t b%c t c-%c n”,i,j,k);)【程序2 3 题目:打印出如下图案(菱形)*L 程序分析:先把图形分成两部分来看待,前四行个规律,后三行一个规律,利用双重fo r 循环,第一层控制行,第二层控制列。2.程序源代码:m ain()(in t i,j,k;fo r(i=0;i=3;i+)(fo r(j=0;j =2-i:j+)p r in t f();fo r (k=0;k =2*i:k+)p r in t f(*);p r in t f(n);)fo r(i=0;i=2;i+)(fo r(j=0;j =i;j+)p r in t fC 3;fo r (k
24、=0;k =4-2*i;k+)p r in t f(*);p r in t f(n);【程序2 4 题目:有一分数序列:2/1,3/2,5/3,8/5,1 3/8,2 1/1 3.求出这个数列的前2 0项之和。1.程序分析:请抓住分子与分母的变化规律。2 .程序源代码:m ain()(in t n,t,n u m ber=2 0;fl o at a=2,b=l,s=0;fo r (n=l;n =n u m ber;n+)(s=s+a/b;t=a;a=a+b;b=t;/*这部分是程序的关键,请读者猜猜t的作用*/p r in t f(s u m is%9.6 f n,s);【程序2 5 题目:求
25、 l+2!+3!+.+2 0!的和1.程序分析:此程序只是把累加变成了累乘。2.程序源代码:m ain ()(fl o at n,s=0,t=l;fo r(n=l;n =2 0;n+)(t*=n;s+=t;)p r in t f(,zl+2!+3!.+2 0!=%e n,s);)【程序2 6 题目:利用递归方法求5!。1.程序分析:递归公式:fn=fn _l*4!2 .程序源代码:#in cl u de“s t dio.h m ai n ()(in t i;in t fact O;fo r(i=0;i 5;i+)p r in l f(4 0:%d!=%d n,i,fact(i);in t fa
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 复件 语言 编程 经典 100
限制150内