实验3
实验任务1
源代码:
#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:
将输入的分数转化为对应的等级,形参类型为整数类型,返回值类型为字符类型
问题2:
缺少break,判断完等级后不会立即停止
实验任务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) { int ans = 0; while(n != 0) { ans += n % 10; n /= 10; } return ans; }
运行截图:

问题1:
功能是计算输入的整数n的各个位数上数字的和
问题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; } }
运行截图:

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

实验任务4
源代码:
#include<stdio.h> int sushu(int n); int main() { printf("100以内的孪生素数:\n"); int count=0; for(int n=2;n<=98;n++) { if(sushu(n)&&sushu(n+2)) { printf("%d %d",n,n+2); printf("\n"); count+=1; }} printf("100以内的孪生素数共有%d个",count); return 0; } int sushu(int n) { for(int i=2;i*i<=n;i++) { if(n%i==0) return 0; } return 1; }
运行截图:

实验任务5
源代码:
#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 fenzi=1,fenmu=1; if(m>n) return 0; else if(m==n||m==0) return 1; elsereturn 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 fenzi=1,fenmu=1; if(m>n) return 0; else if(m==n||m==0) return 1; else for(int i=1;i<=m;i++) { fenmu*=i; fenzi*=(n-m+i); } return fenzi/fenmu; }
运行截图:


实验任务6
源代码:
#include <stdio.h> int gcd(int a,int b,int c); int main() { int a, b, c; int ans; while(scanf("%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 max=0; for(int i=1;i<=a;i++) { if(a%i==0&&b%i==0&c%i==0&&i>max) max=i; } return max; }
运行截图:

实验任务7
源代码:
#include <stdio.h> #include <stdlib.h> void print_charman(int n); void xiaoren(); int main() { int n; printf("Enter n: "); scanf("%d", &n); print_charman(n); return 0; } void print_charman(int n) { int hangshu=0; for(int i=0;i<n;i++) { hangshu+=i; } for(int line=1;line<=hangshu;line++) { int space=(line-1)*8; int count= (hangshu-line+1)*2-1; for(int i=0;i<space;i++) { printf(" "); } for(int geshu=count;geshu>=1;geshu--) { printf(" 0 "); printf("\t"); } printf("\n"); for(int i=0;i<space;i++) { printf(" "); } for(int geshu=count;geshu>=1;geshu--) { printf("<H>"); printf("\t"); } printf("\n"); for(int i=0;i<space;i++) { printf(" "); } for(int geshu=count;geshu>=1;geshu--) { printf("I I"); printf("\t"); } printf("\n\n"); } }
运行截图:


浙公网安备 33010602011771号