📄 11.html
字号:
<html>
<head>
<title>C程序设计11-20</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<link rel="stylesheet" href="cs.css" type="text/css">
<link rel="stylesheet" href="cc.css" type="text/css">
</head>
<body bgcolor="#6666FF" text="#FFFFFF" link="#99FF33" alink="#00CC00" vlink="#FFFF00">
<table width="100%" border="0" cellspacing="0" cellpadding="0">
<tr>
<td width="21%"> </td>
<td>
<div align="center"><br>
<span class="unnamed1"> <font color="#FFFF00" size="3">经典c程序100例==11--20
</font></span> </div>
<p class="unnamed1"><span class="unnamed1">【程序11】<br>
题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月<br>
后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?<br>
1.程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21....<br>
2.程序源代码:<br>
main()<br>
{<br>
long f1,f2;<br>
int i;<br>
f1=f2=1;<br>
for(i=1;i<=20;i++)<br>
{ printf("%12ld %12ld",f1,f2);<br>
if(i%2==0) printf("\n");/*控制输出,每行四个*/<br>
f1=f1+f2; /*前两个月加起来赋值给第三个月*/<br>
f2=f1+f2; /*前两个月加起来赋值给第三个月*/<br>
}<br>
}<br>
==============================================================<br>
【程序12】<br>
题目:判断101-200之间有多少个素数,并输出所有素数。<br>
1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,<br>
则表明此数不是素数,反之是素数。 <br>
2.程序源代码:<br>
#include "math.h"<br>
main()<br>
{<br>
int m,i,k,h=0,leap=1;<br>
printf("\n");<br>
for(m=101;m<=200;m++)<br>
{ k=sqrt(m+1);<br>
for(i=2;i<=k;i++)<br>
if(m%i==0)<br>
{leap=0;break;}<br>
if(leap) {printf("%-4d",m);h++;<br>
if(h%10==0)<br>
printf("\n");<br>
}<br>
leap=1;<br>
}<br>
printf("\nThe total is %d",h);<br>
}<br>
==============================================================<br>
【程序13】<br>
题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数<br>
本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。<br>
1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。<br>
2.程序源代码:<br>
main()<br>
{<br>
int i,j,k,n;<br>
printf("'water flower'number is:");<br>
for(n=100;n<1000;n++)<br>
{<br>
i=n/100;/*分解出百位*/<br>
j=n/10%10;/*分解出十位*/<br>
k=n%10;/*分解出个位*/<br>
if(i*100+j*10+k==i*i*i+j*j*j+k*k*k)<br>
{<br>
printf("%-5d",n);<br>
}<br>
}<br>
printf("\n");<br>
}<br>
==============================================================<br>
【程序14】<br>
题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。</span></p>
<p class="unnamed1"><span class="unnamed1">程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:
<br>
(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。<br>
(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,<br>
重复执行第一步。<br>
(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。</span></p>
<p class="unnamed1"><span class="unnamed1">2.程序源代码:<br>
/* zheng int is divided yinshu*/<br>
main()<br>
{<br>
int n,i;<br>
printf("\nplease input a number:\n");<br>
scanf("%d",&n);<br>
printf("%d=",n);<br>
for(i=2;i<=n;i++)<br>
{<br>
while(n!=i)<br>
{<br>
if(n%i==0)<br>
{ printf("%d*",i);<br>
n=n/i;<br>
}<br>
else<br>
break;<br>
}<br>
}<br>
printf("%d",n);}<br>
==============================================================<br>
【程序15】<br>
题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,<br>
60分以下的用C表示。<br>
1.程序分析:(a>b)?a:b这是条件运算符的基本例子。<br>
2.程序源代码:<br>
main()<br>
{<br>
int score;<br>
char grade;<br>
printf("please input a score\n");<br>
scanf("%d",&score);<br>
grade=score>=90?'A':(score>=60?'B':'C');<br>
printf("%d belongs to %c",score,grade);<br>
}<br>
==============================================================<br>
【程序16】<br>
题目:输入两个正整数m和n,求其最大公约数和最小公倍数。<br>
1.程序分析:利用辗除法。</span></p>
<p class="unnamed1"><span class="unnamed1">2.程序源代码:<br>
main()<br>
{<br>
int a,b,num1,num2,temp;<br>
printf("please input two numbers:\n");<br>
scanf("%d,%d",&num1,&num2);<br>
if(num1 { temp=num1;<br>
num1=num2; <br>
num2=temp;<br>
}<br>
a=num1;b=num2;<br>
while(b!=0)/*利用辗除法,直到b为0为止*/<br>
{<br>
temp=a%b;<br>
a=b;<br>
b=temp;<br>
}<br>
printf("gongyueshu:%d\n",a);<br>
printf("gongbeishu:%d\n",num1*num2/a);<br>
}<br>
==============================================================<br>
【程序17】<br>
题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。<br>
1.程序分析:利用while语句,条件为输入的字符不为'\n'.<br>
<br>
2.程序源代码:<br>
#include "stdio.h"<br>
main()<br>
{char c;<br>
int letters=0,space=0,digit=0,others=0;<br>
printf("please input some characters\n");<br>
while((c=getchar())!='\n')<br>
{<br>
if(c>='a'&&c<='z'||c>='A'&&c<='Z')<br>
letters++;<br>
else if(c==' ')<br>
space++;<br>
else if(c>='0'&&c<='9')<br>
digit++;<br>
else<br>
others++;<br>
}<br>
printf("all in all:char=%d space=%d digit=%d others=%d\n",letters,<br>
space,digit,others);<br>
}<br>
==============================================================<br>
【程序18】<br>
题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时<br>
共有5个数相加),几个数相加有键盘控制。<br>
1.程序分析:关键是计算出每一项的值。<br>
2.程序源代码:<br>
main()<br>
{<br>
int a,n,count=1;<br>
long int sn=0,tn=0;<br>
printf("please input a and n\n");<br>
scanf("%d,%d",&a,&n);<br>
printf("a=%d,n=%d\n",a,n);<br>
while(count<=n)<br>
{<br>
tn=tn+a;<br>
sn=sn+tn;<br>
a=a*10;<br>
++count;<br>
}<br>
printf("a+aa+...=%ld\n",sn);<br>
}<br>
==============================================================<br>
【程序19】<br>
题目:一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程<br>
找出1000以内的所有完数。<br>
1. 程序分析:请参照程序<--上页程序14. <br>
2.程序源代码:<br>
main()<br>
{<br>
static int k[10];<br>
int i,j,n,s;<br>
for(j=2;j<1000;j++)<br>
{<br>
n=-1;<br>
s=j;<br>
for(i=1;i {<br>
if((j%i)==0)<br>
{ n++;<br>
s=s-i;<br>
k[n]=i;<br>
}<br>
}<br>
if(s==0)<br>
{<br>
printf("%d is a wanshu",j);<br>
for(i=0;i printf("%d,",k[i]);<br>
printf("%d\n",k[n]);<br>
}<br>
}<br>
}<br>
============================================================== <br>
【程序20】<br>
题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在<br>
第10次落地时,共经过多少米?第10次反弹多高?<br>
1.程序分析:见下面注释<br>
2.程序源代码:<br>
main()<br>
{<br>
float sn=100.0,hn=sn/2;<br>
int n;<br>
for(n=2;n<=10;n++)<br>
{<br>
sn=sn+2*hn;/*第n次落地时共经过的米数*/<br>
hn=hn/2; /*第n次反跳高度*/<br>
}<br>
printf("the total of road is %f\n",sn);<br>
printf("the tenth is %f meter\n",hn);<br>
}<br>
</span> </p>
</td>
<td width="21%"> </td>
</tr>
</table>
</body>
</html>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -