实验3

实验任务1 问题1:作用是根据输入的分数对应相应的等级。形参类型是整数型,返回值类型是字符型

 

问题2:更改后代码的问题是:1.输入的分数会对应输出对应的等级以及对应等级以下的等级。 2.更改后的代码没有返回值。

实验任务2 问题1:功能是让输入的n值有相应的ans值。

 #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;
}
 #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) {int sum_digits(int n) {
    int ans = 0;
    while(n != 0) {
        ans += n % 10;
        n /= 10;
    }
    return ans;
}

批注 2025-10-24 085730

 

问题2:能。第一种算法思维是迭代。第二种算法思维是递归。

实验任务3 

 #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;
    }
}

 

批注 2025-10-24 085730

问题1:power的功能是计算x的n次方的值

问题2:

实验任务4

 

#include <stdio.h>
int is_prime(int n);

int main() {
    int count = 0;
    printf("100以内的孪生素数:\n");
    for (int n = 2; n <= 98; n++) {
        if (is_prime(n) && is_prime(n + 2)) {
            printf("%d %d\n", n, n + 2);
            count += 1;
        }

    }

    printf("100以内的孪生素数有%d个", count);

    return 0;

}

int is_prime(int n) {
    if (n <= 2) {
        return 0;
    }
    for (int i = 2; i* i <= n; i++)
    {
        if (n % i == 0)
            return 0;
    }

    return 1;
}

运行结果

屏幕截图 2025-10-25 215838

实验任务5

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

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

    while (scanf_s("%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 ans;
    if (n < m) {
        return 0;
    }
    if (m == 0 || m == n) {
        return 1;
    }
    return func(n - 1, m) + func(n - 1, m - 1);

}

 

int func(int n, int m) {
    int ans;
    int f1 = n-m+1;
    int f2 = 1;
    int a = 1;
    int b = 1;
    if (n < m) {
        return 0;
    }
    for (int i = 1; i <= m; i++) {
        a *= f1;
        f1++;
        b *= f2;
        f2++;
    }
    ans = a / b;
    return ans;

}

运行结果

屏幕截图 2025-10-26 163444

 

屏幕截图 2025-10-25 223144

实验任务6

#include <stdio.h>

int gcd(int a, int b, int c);


int main() {
    int a, b, c;
    int ans;

    while (scanf_s("%d%d%d", &a, &b, &c) != EOF) {
        ans = gcd(a, b, c);     // 函数调用
        printf("最大公约数: %d\n\n", ans);
    }

    return 0;
}


int gcd(int a, int b, int c) {
    int min = a < b ? (a < c ? a : c) : (b < c ? b : c);
    for (int d = min; d > 1; d--) {
        if (a % d == 0 && b % d == 0 && c % d == 0) {
            return d;
        }
    }
}

运行结果

屏幕截图 2025-10-25 231649

实验任务7

#include <stdio.h>
#include <stdlib.h>

void print_charman(int n);
int main() {
    int n;

    printf("Enter n: ");
    scanf("%d", &n);
    print_charman(n); // 函数调用
       
    return 0;
}
     
void print_charman(int n){
    int i,line,m;
    for(i=n;i>=1;--i){
        for(line=1;line<=7*(n-i);++line){
            printf(" ");}
        for(m=1;m<=2*i-1;++m){
            printf(" 0     ");}
        printf("\n");
         
         
         for(line=1;line<=7*(n-i);++line){
            printf(" ");}
        for(m=1;m<=2*i-1;++m){
            printf("<H>    ");}
        printf("\n");
        
        
          for(line=1;line<=7*(n-i);++line){
            printf(" ");}
        for(m=1;m<=2*i-1;++m){
            printf("I I    ");}
        printf("\n");
        
        
        printf("\n\n");
    }
}

运行结果

屏幕截图 2025-10-30 190350

 

posted @ 2025-10-30 19:06  |l|  阅读(3)  评论(0)    收藏  举报