C/C++之习题11-15
来源:互联网 发布:试卷制作软件 编辑:程序博客网 时间:2024/06/04 01:28
【程序11】
题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月
后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
1.程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21….
#include<stdio.h>#include<stdlib.h> int main(){ long i,j; long f1,f2; f1 = f2 = 1; printf("斐波那契数列(Fibonacci sequence)\n"); printf("%ld %ld ",f1,f2); for(i = 3;i<=20;i++){ // 1 ,1 ,2 ,3 ,5, 8,13,21...... // printf("%c%c",219,219);在dos下是可以输出一个黑框框,win下不行 printf("%ld ",f1+f2); j = f1; f1 =f2; f2=j+f2; } printf("\n"); system("pause"); return 0; }
【程序12】
题目:判断101-200之间有多少个素数,并输出所有素数。
1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,
则表明此数不是素数,反之是素数。
#include<stdio.h>#include<stdlib.h>int main(){ int i,j; printf("输出素数为\n"); for(i = 101;i<=200;i=i+2){ int flag = 1; for(j =3;j<=sqrt(i);j++ ){ if(i%j == 0){ flag = 0; break;} } if(flag == 1){ printf("%d\t",i); } } system("pause"); return 0; }
改进
#include<stdio.h>#include<stdlib.h>int main(){ int i,j; printf("输出素数为\n"); for(i = 101;i<=200;i=i+2){ int flag = 1; if(i%3 == 0 || i%5 == 0){ printf("\n等于3或者5的数%d\n",i); continue; } for(j =3;j<=sqrt(i);j++ ){ if(i%j == 0){ flag = 0; break;} } if(flag == 1){ printf("%d\t",i); } } system("pause"); return 0; }
【程序13】
题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数
本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。
1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。
函数名: pow 功 能: 指数函数(x的y次方) 用 法: double pow(double x, double y); 程序例: #include <math.h> #include <stdio.h> int main(void) { double x = 2.0, y = 3.0; printf("%lf raised to %lf is %lf\n", x, y, pow(x, y)); return 0; } 函数名: pow10 功 能: 指数函数(10的p次方) 用 法: double pow10(int p); 程序例: #include <math.h> #include <stdio.h> int main(void) { double p = 3.0; printf("Ten raised to %lf is %lf\n", p, pow10(p)); return 0; }
水仙花数
#include<stdio.h>#include<stdlib.h>#include<math.h>int main(){ int i,j; printf("输出水仙花数\n"); for(i = 100;i<=999;i++){ int flag = 1; if((pow(i%100/10,3)+pow(i%10,3)+pow(i/100,3)) == i){ printf("%d\t",i); }} system("pause"); return 0; }
【程序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的值,重复执行第一步。
#include<stdio.h>#include<stdlib.h>#include<math.h>int main(){ int i,j=1,number; printf("分解质因数\n"); printf("输入一个数\n"); scanf("%d",&number); printf("%d=",number); int flag =number; for(i = 2;i<=flag;i++){ // printf("进来了么"); if(flag%i==0){ if(j == 1){ printf("%d",i); }else{ printf("*%d",i); } j++; flag =flag/i; i = 1; }} printf("\n"); system("pause"); return 0; }
【程序15】
题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,
60分以下的用C表示。
1.程序分析:(a>b)?a:b这是条件运算符的基本例子。
#include<stdio.h>#include<stdlib.h>#include<math.h>int main(){ int i,score; printf("请输入分数\n"); scanf("%d",&score); char flag; flag = score>89?'A':(score>59?'B':'N'); printf("%c",flag);printf("\n"); system("pause"); return 0; }
0 0
- C/C++之习题11-15
- 《C语言之习题大全》
- C语言之经典习题
- C语言习题之数组
- 习题(C++) 04-7-15
- C语言经典编程习题之循环
- C/C++之习题6-10
- C/C++之习题16-20
- C++primer第15章习题解答
- c primer plus 11章习题答案
- C Peimer第11章编程习题
- C++primer[习题][第一章][11-20]
- C++primer[习题][第二章][11-20]
- C++primer[习题][第三章][11-20]
- C++primer[习题][第四章][11-20]
- C习题(team)
- c++primer 习题9.12
- c++primer 习题9.35
- CNN卷积神经网络--反向传播(2,前向传播)
- JQuery 动画 滑动卷入 淡入淡出
- 轻量级便捷DIY的遮罩
- 通过OAuth2.0方式弹出授权页面获得用户基本信息
- Android发送邮件mark
- C/C++之习题11-15
- shell脚本学习4——shell运算符
- 16位汇编 数据段 栈段 代码段
- java.util.Date和java.sql.Date的区别和相互转化
- 基于live555实现的跨平台高性能RTSPServer流媒体服务器EasyIPCamera
- struts注解配置
- jscese 知其白 守其黑 為天下式 __Read The Fucking Source Code的博客汇总
- %运算符
- 【android开发】自定义数字软键盘的设计与实现(2)