实验三

任务一

源代码

#include <stdio.h>

char score_to_grade(int score); 

int main() {
    int score;
    char grade;

    while(scanf("%d", &score) != EOF) {
        grade = score_to_grade(score); 
        printf("分数: %d, 等级: %c\n\n", score, grade);
    }


    return 0;
}


char score_to_grade(int score) {
    char ans;

    switch(score/10) {
    case 10:
    case 9:   ans = 'A'; break;
    case 8:   ans = 'B'; break;
    case 7:   ans = 'C'; break;
    case 6:   ans = 'D'; break;
    default:  ans = 'E';
    }

    return ans;
}

运行结果

问题1  根据分数判断等第  形参类型为int   返回值类型为char

问题2 有问题 在判断出分数所属的等第后程序不会进入下一个循环 而是接着执行相对应

 

 

任务二

源代码

#include <stdio.h>

int sum_digits(int n);  

int main() {
    int n;
    int ans;


    while(printf("Enter n: "), scanf("%d", &n) != EOF) {
        ans = sum_digits(n);  
        printf("n = %d, ans = %d\n\n", n, ans);
    }


    return 0;
}


int sum_digits(int n) {
   if(n<10)
   return n;
 
   
   return sum_digits(n/10)+n%10;
}

运行结果

问题1  根据输入的数字,算出各个位数上的数字的和

问题2  能实现  第一种方法是迭代

                     第二种方法是递归 

 

任务三

源代码

#include <stdio.h>

int power(int x, int n);  

int main() {
    int x, n;
    int ans;

    while(printf("Enter x and n: "), scanf("%d%d", &x, &n) != EOF) {
        ans = power(x, n);
        printf("n = %d, ans = %d\n\n", n, ans);
    }
    
    return 0;
}
int power(int x, int n) {
    int t;

    if(n == 0)
        return 1;
    else if(n % 2)
        return x * power(x, n-1);
    else {
        t = power(x, n/2);
        return t*t;
    }
}

运行结果

 

 

问题1   求 n的x次幂

 问题2   

任务4

源代码

#include<stdio.h>
int is_prime(int n);
int main(){
    int n;
    int ans=0; 
    printf("100以内的孪生素数:\n");
    for(n=2;n<=100;n++){
        if(is_prime(n)&&is_prime(n+2)){
        
        
        printf("%d %d\n",n,n+2);
   ans+=1;
   }
    }
   
    printf("100以内的孪生素数共有%d个",ans);
    return 0;
}
int is_prime(int n)
{
  int k;
  for(k=2;k<=n/2;k++)
     if(n%k==0)
       return 0;
   return 1;
    
}

运行结果

任务5

源代码

#include <stdio.h>
#include <stdlib.h>
void hanoi(unsigned int n,char from,char temp,char to);
    void moveplate(unsigned int n,char from,char to);
    int ans=0;
int main(){

    unsigned int n;
    while(scanf("%u",&n)!=EOF){

    hanoi(n,'A','B','C');

    printf("一共移动了%d次\n",ans);
    system("pause");

}
    return 0;

}
void hanoi(unsigned int n,char from,char temp,char to)
{

    if(n==1){
    ans+=1;
    moveplate(n,from,to);

}
    else
    {

        hanoi(n-1,from,to,temp);
        ans+=1;
        moveplate(n,from,to);

        hanoi(n-1,temp,from,to);


    }

}
void moveplate(unsigned int n,char from,char to)
{int ans=0;
    printf("%u:%c-->%c\n",n,from,to);
    ans+=1;
}

运行结果

任务6

源代码 递归

#include <stdio.h>
int func(int n, int m);   // 函数声明

int main() {
    int n, m;
    int ans;

    while(scanf("%d%d", &n, &m) != EOF) {
        ans = func(n, m);   // 函数调用
        printf("n = %d, m = %d, ans = %d\n\n", n, m, ans);
    }
        
    return 0;
}
int func(int n,int m)
{

    if(m==0||n==m)
    return 1;
    if(m>n)
    return 0;
        return func(n-1,m)+func(n-1,m-1);
    
}

迭代

#include <stdio.h>
int func(int n, int m);   // 函数声明

int main() {
    int n, m;
    int ans;

    while(scanf("%d%d", &n, &m) != EOF) {
        ans = func(n, m);   // 函数调用
        printf("n = %d, m = %d, ans = %d\n\n", n, m, ans);
    }
        
    return 0;
}
int func(int n,int m)
{
   int i,a=1,b=1;
   if (m>n)
   return 0;
   for(i=0;i<m;i++)
   {
       a=a*n--;
    a=a/b++;
   }
return a;
}

运行结果

递归

迭代

任务7

#include<stdio.h>
#include<stdlib.h>
char print_charman(int n);
int main(){
    int n;
    printf("Enter n:");
    scanf("%d",&n);
    print_charman(n);
    return 0;
} 
char print_charman(int n)
{
    int t=0;
    for(int i=n;i>=1;i--)
    {
        for(int j=0;j<t;j++)
        printf("\t");
        for(int j=0;j<2*i-1;j++)
        printf(" o\t");
        printf("\n");
        for(int j=0;j<t;j++)
           printf("\t");
           for(int j=0;j<2*i-1;j++)
        printf("<H>\t");
        printf("\n");
            for(int j=0;j<t;j++)
              printf("\t");
              for(int j=0;j<2*i-1;j++)
              printf("I I\t");
        printf("\n");
        t++;
              
    }
}

运行结果

 

posted @ 2024-10-28 13:08  wsj1204  阅读(3)  评论(0编辑  收藏  举报