C语言经典编程实例100题+答案.docx
《C语言经典编程实例100题+答案.docx》由会员分享,可在线阅读,更多相关《C语言经典编程实例100题+答案.docx(65页珍藏版)》请在冰豆网上搜索。
C语言经典编程实例100题+答案
C语言程序实例100个
(一)
【程序1】ﻫ题目:
有1、2、3、4个数字,能组成多少个互不相同且无重复数字得三位数?
都就是多少?
1、程序分析:
可填在百位、十位、个位得数字都就是1、2、3、4。
组成所有得排列后再去掉不满足条件得排列。
2、程序源代码:
ﻫmain()
{ﻫint i,j,k;ﻫprintf("\n");ﻫfor(i=1;i<5;i++) /*以下为三重循环*/ for(j=1;j<5;j++)
for (k=1;k<5;k++)ﻫ {
if (i!
=k&&i!
=j&&j!
=k) /*确保i、j、k三位互不相同*/ printf("%d,%d,%d\n",i,j,k);
}ﻫ}ﻫ==============================================================ﻫ【程序2】
题目:
企业发放得奖金根据利润提成。
利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元得部分按10%提成,高于10万元得部分,可可提成7、5%;20万到40万之间时,高于20万元得部分,可提成5%;40万到60万之间时高于40万元得部分,可提成3%;60万到100万之间时,高于60万元得部分,可提成1、5%,高于100万元时,超过100万元得部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?
1、程序分析:
请利用数轴来分界,定位。
注意定义时需把奖金定义成长整型。
ﻫ2、程序源代码:
ﻫmain()
{ﻫlong int i;ﻫint bonus1,bonus2,bonus4,bonus6,bonus10,bonus;
scanf("%ld",&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;ﻫ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-600000)*0、015;ﻫ elseﻫ bonus=bonus10+(i-1000000)*0、01;ﻫprintf("bonus=%d",bonus);
}
ﻫ==============================================================ﻫ【程序3】ﻫ题目:
一个整数,它加上100后就是一个完全平方数,再加上168又就是一个完全平方数,请问该数就是多少?
1、程序分析:
在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后得结果满足如下条件,即就是结果。
请瞧具体分析:
ﻫ2、程序源代码:
#i nclude "math、h"ﻫmain()ﻫ{ﻫlong int i,x,y,z;ﻫfor (i=1;i<100000;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】ﻫ题目:
输入某年某月某日,判断这一天就是这一年得第几天?
1、程序分析:
以3月5日为例,应该先把前两个月得加起来,然后再加上5天即本年得第几天,特殊情况,闰年且输入月份大于3时需考虑多加一天。
ﻫ2、程序源代码:
ﻫmain()ﻫ{ﻫint day,month,year,sum,leap;ﻫprintf("\nplease input year,month,day\n");
scanf("%d,%d,%d",&year,&month,&day);
switch(month)/*先计算某月以前月份得总天数*/ {ﻫcase 1:
sum=0;break;
case 2:
sum=31;break;ﻫ case 3:
sum=59;break;ﻫ case 4:
sum=90;break;
case 5:
sum=120;break;
case 6:
sum=151;break;ﻫ case 7:
sum=181;break;ﻫcase 8:
sum=212;break;ﻫcase 9:
sum=243;break;
case 10:
sum=273;break;ﻫ case 11:
sum=304;break;ﻫcase 12:
sum=334;break;
default:
printf("data error");break;ﻫ}
sum=sum+day; /*再加上某天得天数*/ if(year%400==0||(year%4==0&&year%100!
=0))/*判断就是不就是闰年*/ leap=1;ﻫ elseﻫ leap=0;ﻫif(leap==1&&month>2)/*如果就是闰年且月份大于2,总天数应该加一天*/ sum++;
printf("It is the %dth day、",sum);}ﻫ==============================================================
【程序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("small to big:
%d %d %d\n",x,y,z);
}ﻫ==============================================================
【程序6】
题目:
用*号输出字母C得图案。
ﻫ1、程序分析:
可先用'*'号在纸上写出字母C,再分行输出。
ﻫ2、程序源代码:
ﻫ#i nclude "stdio、h"ﻫmain()
{
printf("Hello C-world!
\n");
printf(" ****\n");
printf(" *\n");
printf(" * \n");ﻫprintf(" ****\n");
}ﻫ==============================================================
【程序7】ﻫ题目:
输出特殊图案,请在c环境中运行,瞧一瞧,Very Beautiful!
1、程序分析:
字符共有256个。
不同字符,图形不一样。
ﻫ2、程序源代码:
#i nclude "stdio、h"ﻫmain()ﻫ{
char a=176,b=219;ﻫprintf("%c%c%c%c%c\n",b,a,a,a,b);
printf("%c%c%c%c%c\n",a,b,a,b,a);ﻫprintf("%c%c%c%c%c\n",a,a,b,a,a);ﻫprintf("%c%c%c%c%c\n",a,b,a,b,a);
printf("%c%c%c%c%c\n",b,a,a,a,b);}
==============================================================ﻫ【程序8】
题目:
输出9*9口诀。
ﻫ1、程序分析:
分行与列考虑,共9行9列,i控制行,j控制列。
2、程序源代码:
#i nclude "stdio、h"ﻫmain()
{
int i,j,result;ﻫ printf("\n");ﻫfor (i=1;i<10;i++)ﻫ { for(j=1;j<10;j++)ﻫ {ﻫ result=i*j;ﻫ printf("%d*%d=%-3d",i,j,result);/*-3d表示左对齐,占3位*/ }
printf("\n");/*每一行后换行*/ }
}ﻫ==============================================================ﻫ【程序9】ﻫ题目:
要求输出国际象棋棋盘。
1、程序分析:
用i控制行,j来控制列,根据i+j得与得变化来控制输出黑方格,还就是白方格。
ﻫ2、程序源代码:
ﻫ#i nclude "stdio、h"ﻫmain()ﻫ{
int i,j;
for(i=0;i<8;i++)ﻫ{ﻫ for(j=0;j<8;j++)
if((i+j)%2==0)ﻫ printf("%c%c",219,219);
elseﻫ printf(" ");ﻫ printf("\n");ﻫ }
}
==============================================================
【程序10】ﻫ题目:
打印楼梯,同时在楼梯上方打印两个笑脸。
ﻫ1、程序分析:
用i控制行,j来控制列,j根据i得变化来控制输出黑方格得个数。
2、程序源代码:
ﻫ#i nclude "stdio、h"ﻫmain()
{
int i,j;
printf("\1\1\n");/*输出两个笑脸*/ for(i=1;i<11;i++)ﻫ {
for(j=1;j<=i;j++)
printf("%c%c",219,219);ﻫ printf("\n");ﻫ}ﻫ}ﻫ【程序11】
题目:
古典问题:
有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月得兔子总数为多少?
ﻫ1、程序分析:
兔子得规律为数列1,1,2,3,5,8,13,21、、、、ﻫ2、程序源代码:
main()ﻫ{
long f1,f2;
int i;ﻫf1=f2=1;ﻫfor(i=1;i<=20;i++)
{ printf("%12ld %12ld",f1,f2);
if(i%2==0) printf("\n");/*控制输出,每行四个*/ f1=f1+f2; /*前两个月加起来赋值给第三个月*/ f2=f1+f2; /*前两个月加起来赋值给第三个月*/ }
}
==============================================================ﻫ【程序12】
题目:
判断101-200之间有多少个素数,并输出所有素数。
ﻫ1、程序分析:
判断素数得方法:
用一个数分别去除2到sqrt(这个数),如果能被整除, 则表明此数不就是素数,反之就是素数。
2、程序源代码:
ﻫ#i nclude "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==0)
{leap=0;break;}ﻫif(leap) {printf("%-4d",m);h++;
if(h%10==0)ﻫ printf("\n");
}ﻫ leap=1;
}
printf("\nThe total is %d",h);ﻫ}
==============================================================
【程序13】ﻫ题目:
打印出所有得“水仙花数”,所谓“水仙花数”就是指一个三位数,其各位数字立方与等于该数本身。
例如:
153就是一个“水仙花数”,因为153=1得三次方+5得三次方+3得三次方。
1、程序分析:
利用for循环控制100-999个数,每个数分解出个位,十位,百位。
2、程序源代码:
ﻫmain()ﻫ{ﻫint i,j,k,n;
printf("'water flower'number is:
");ﻫ for(n=100;n<1000;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");ﻫ}
==============================================================ﻫ【程序14】ﻫ题目:
将一个正整数分解质因数。
例如:
输入90,打印出90=2*3*3*5。
ﻫ
程序分析:
对n进行分解质因数,应先找到一个最小得质数k,然后按下述步骤完成:
ﻫ(1)如果这个质数恰等于n,则说明分解质因数得过程已经结束,打印出即可。
(2)如果n<>k,但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",&n);ﻫprintf("%d=",n);
for(i=2;i<=n;i++)
{
while(n!
=i)
{ﻫ if(n%i==0)
{ printf("%d*",i);ﻫ n=n/i;
}ﻫelseﻫ break;ﻫ }ﻫ}
printf("%d",n);}ﻫ==============================================================ﻫ【程序15】
题目:
利用条件运算符得嵌套来完成此题:
学习成绩>=90分得同学用A表示,60-89分之间得用B表示,60分以下得用C表示。
ﻫ1、程序分析:
(a>b)?
a:
b这就是条件运算符得基本例子。
ﻫ2、程序源代码:
ﻫmain()
{
int score;ﻫ char grade;ﻫprintf("please input a score\n");ﻫ scanf("%d",&score);
grade=score>=90?
'A':
(score>=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("%d,%d",&num1,&num2);ﻫ 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:
%d\n",a);ﻫprintf("gongbeishu:
%d\n",num1*num2/a);
}
==============================================================
【程序17】
题目:
输入一行字符,分别统计出其中英文字母、空格、数字与其它字符得个数。
1、程序分析:
利用while语句,条件为输入得字符不为'\n'、ﻫ2、程序源代码:
ﻫ#i nclude "stdio、h"ﻫmain()ﻫ{char c;ﻫ int letters=0,space=0,digit=0,others=0;
printf("please input some characters\n");
while((c=getchar())!
='\n')
{
if(c>='a'&&c<='z'||c>='A'&&c<='Z')ﻫ letters++;
else if(c==' ')
space++;
else if(c>='0'&&c<='9')
digit++;ﻫ elseﻫ others++;ﻫ}
printf("all in all:
char=%d space=%d digit=%d others=%d\n",letters,
space,digit,others);
}ﻫ==============================================================
【程序18】
题目:
求s=a+aa+aaa+aaaa+aa、、、a得值,其中a就是一个数字。
例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。
1、程序分析:
关键就是计算出每一项得值。
ﻫ2、程序源代码:
ﻫmain()
{ﻫ int a,n,count=1;
long int sn=0,tn=0;ﻫ printf("please input a and n\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("a+aa+、、、=%ld\n",sn);ﻫ}
==============================================================ﻫ【程序19】
题目:
一个数如果恰好等于它得因子之与,这个数就称为“完数”。
例如6=1+2+3、编程 找出1000以内得所有完数。
1、 程序分析:
请参照程序<--上页程序14、 ﻫ2、程序源代码:
ﻫmain()
{ﻫstatic int k[10];ﻫint i,j,n,s;
for(j=2;j<1000;j++)
{ﻫ n=-1;ﻫs=j;ﻫ for(i=1;i {ﻫ if((j%i)==0)ﻫ{ n++;ﻫ s=s-i;ﻫ k[n]=i;ﻫ }ﻫ }ﻫ if(s==0)
{ﻫprintf("%d is a wanshu",j);ﻫ for(i=0;i printf("%d,",k[i]);
printf("%d\n",k[n]);ﻫ }
}
}ﻫ============================================================== ﻫ【程序20】ﻫ题目:
一球从100米高度自由落下,每次落地后反跳回原高度得一半;再落下,求它在第10次落地时,
ﻫ【程序13】ﻫ题目:
打印出所有得“水仙花数”,所谓“水仙花数”就是指一个三位数,其各位数字立方与等于该数本身。
例如:
153就是一个“水仙花数”,因为153=1得三次方+5得三次方+3得三次方。
1、程序分析:
利用for循环控制100-999个数,每个数分解出个位,十位,百位。
2、程序源代码:
ﻫmain()ﻫ{
int i,j,k,n;
printf("'water flower'number is:
");
for(n=100;n<1000;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");
}ﻫ==============================================================ﻫ【程序14】
题目:
将一个正整数分解质因数。
例如:
输入90,打印出90=2*3*3*5。
程序分析:
对n进行分解质因数,应先找到一个最小得质数k,然后按下述步骤完成:
(1)如果这个质数恰等于n,则说明分解质因数得过程已经结束,打印出即可。
ﻫ
(2)如果n<>k,但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",&n);ﻫprintf("%d=",n);
for(i=2;i<=n;i++)ﻫ {
while(n!
=i)
{ﻫ if(n%i==0)ﻫ { printf("%d*",i);
n=n/i;ﻫ }ﻫ else
break;ﻫ }
}ﻫprintf("%d",n);}
==============================================================ﻫ【程序15】ﻫ题目:
利用条件运算符得嵌套来完成此题:
学习成绩>=90分得同学用A表示,60-89分之间得用B表示,60分以下得用C表示。
ﻫ1、程序分析:
(a>b)?
a:
b这就是条件运算符得基本例子。
ﻫ2、程序源代码:
ﻫmain()ﻫ{ﻫ int score;ﻫchar grade;ﻫ printf("please input a score\n");ﻫscanf("%d",&score);ﻫgrade=score>=90?
'A':
(score>=60?
'B':
'C');ﻫ printf("%d belongs to %c",score,grade);
}ﻫ==========================================================