C语言程序设计_梁栋_经典c程序100例==11--20.doc

上传人:汽*** 文档编号:559887415 上传时间:2023-01-18 格式:DOC 页数:7 大小:45.51KB
返回 下载 相关 举报
C语言程序设计_梁栋_经典c程序100例==11--20.doc_第1页
第1页 / 共7页
C语言程序设计_梁栋_经典c程序100例==11--20.doc_第2页
第2页 / 共7页
C语言程序设计_梁栋_经典c程序100例==11--20.doc_第3页
第3页 / 共7页
C语言程序设计_梁栋_经典c程序100例==11--20.doc_第4页
第4页 / 共7页
C语言程序设计_梁栋_经典c程序100例==11--20.doc_第5页
第5页 / 共7页
点击查看更多>>
资源描述

《C语言程序设计_梁栋_经典c程序100例==11--20.doc》由会员分享,可在线阅读,更多相关《C语言程序设计_梁栋_经典c程序100例==11--20.doc(7页珍藏版)》请在金锄头文库上搜索。

1、 .:.:经典c程序100例=11-20 :.:. 经典c程序100例=11-20【程序11】题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?1.程序分析:兔子的规律为数列1,1,2,3,5,8,13,21.2.程序源代码:#include stdio.h#include conio.hmain() 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); /*控制输出

2、,每行四个*/ f1=f1+f2; /*前两个月加起来赋值给第三个月*/ f2=f1+f2; /*前两个月加起来赋值给第三个月*/ getch();=【程序12】题目:判断101-200之间有多少个素数,并输出所有素数。1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。 2.程序源代码:#include stdio.h#include conio.h#include math.hmain() int m,i,k,h=0,leap=1; printf(n); for(m=101;m=200;m+) k=sqrt(m+1); for

3、(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); getch();=【程序13】题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个“水仙花数”,因为153=1的三次方5的三次方3的三次方。1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。2.程序源代码:#include stdio.h#include c

4、onio.hmain() int i,j,k,n; printf(water flowernumber is:); for(n=100;n1000;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); getch();=【程序14】题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成: (1)如果这个质数恰等于n,则说明分解质因数的过程

5、已经结束,打印出即可。(2)如果nk,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。2.程序源代码:/* zheng int is divided yinshu*/#include stdio.h#include conio.hmain() int n,i; printf(nplease input a number:n); scanf(%d,&n); printf(%d=,n); for(i=2;i=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。1.程序分析:(

6、ab)?a:b这是条件运算符的基本例子。2.程序源代码:#include stdio.h#include conio.hmain() int score; char grade; printf(please input a scoren); scanf(%d,&score); grade=score=90?A:(score=60?B:C); printf(%d belongs to %c,score,grade); getch();=【程序16】题目:输入两个正整数m和n,求其最大公约数和最小公倍数。1.程序分析:利用辗除法。2.程序源代码:#include stdio.h#include c

7、onio.hmain() int a,b,num1,num2,temp; printf(please input two numbers:n); scanf(%d,%d,&num1,&num2); if(num1=a&c=A&c=0&c=9) digit+; else others+; printf(all in all:char=%d space=%d digit=%d others=%dn,letters, space,digit,others); getch();=【程序18】题目:求s=a+aa+aaa+aaaa+aa.a的值,其中a是一个数字。例如2+22+222+2222+2222

8、2(此时共有5个数相加),几个数相加有键盘控制。1.程序分析:关键是计算出每一项的值。2.程序源代码:#include stdio.h#include conio.hmain() int a,n,count=1; long int sn=0,tn=0; printf(please input a and nn); scanf(%d,%d,&a,&n); printf(a=%d,n=%dn,a,n); while(count=n) tn=tn+a; sn=sn+tn; a=a*10; +count; printf(a+aa+.=%ldn,sn); getch();=【程序19】题目:一个数如果恰

9、好等于它的因子之和,这个数就称为“完数”。例如6=123.编程找出1000以内的所有完数。1. 程序分析:请参照程序-上页程序14. 2.程序源代码:#include stdio.h#include conio.hmain() static int k10; int i,j,n,s; for(j=2;j1000;j+) n=-1; s=j; for(i=1;ij;i+) if(j%i)=0) n+; s=s-i; kn=i; if(s=0) printf(%d is a wanshu,j); for(i=0;in;i+) printf(%d,ki); printf(%dn,kn); getch();=

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号