关闭

C/C++之习题11-15

143人阅读 评论(0) 收藏 举报
分类:

【程序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

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:36731次
    • 积分:1736
    • 等级:
    • 排名:千里之外
    • 原创:137篇
    • 转载:27篇
    • 译文:0篇
    • 评论:4条
    最新评论