实验3

task1

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <time.h>
 4 #include <windows.h>
 5 #define N 80
 6 void print_text(int line, int col, char text[]); // 函数声明
 7 void print_spaces(int n); // 函数声明
 8 void print_blank_lines(int n); // 函数声明
 9 int main() {
10     int line, col, i;
11     char text[N] = "hi, November~";
12     srand(time(0)); // 以当前系统时间作为随机种子
13     for (i = 1; i <= 10; ++i) {
14         line = rand() % 25;
15         col = rand() % 80;
16         print_text(line, col, text);
17         Sleep(1000); // 暂停1000ms
18     }
19     return 0;
20 }
21 // 打印n个空格
22 void print_spaces(int n) {
23     int i;
24     for (i = 1; i <= n; ++i)
25         printf(" ");
26 }
27 // 打印n行空白行
28 void print_blank_lines(int n) {
29     int i;
30     for (i = 1; i <= n; ++i)
31         printf("\n");
32 }
33 // 在第line行第col列打印一段文本
34 void print_text(int line, int col, char text[]) {
35     print_blank_lines(line - 1); // 打印(line-1)行空行
36     print_spaces(col - 1); // 打印(col-1)列空格
37     printf("%s", text); // 在第line行、col列输出text中字符串
38 }

如下图生成(还有4个未显示)

 代码功能:随机在某行某列打印“hi,November”,并在其之后的某行与某列再次打印,重复9次,共打印10个

 

 

 

task2.1

 1 #include <stdio.h>
 2 long long fac(int n); // 函数声明
 3 int main() {
 4     int i, n;
 5     printf("Enter n: ");
 6     scanf("%d", &n);
 7     for (i = 1; i <= n; ++i)
 8         printf("%d! = %lld\n", i, fac(i));
 9     return 0;
10 }
11 // 函数定义
12 long long fac(int n) {
13     static long long p = 1;
14     //printf("p = %lld\n", p);
15     p = p * n;
16     return p;
17 }

 

task2.2

 1 #include <stdio.h>
 2 int func(int, int); // 函数声明
 3 int main() {
 4     int k = 4, m = 1, p1, p2;
 5     p1 = func(k, m); // 函数调用
 6     
 7     p2 = func(k, m); // 函数调用
 8     printf("%d, %d\n", p1, p2);
 9     return 0;
10 }
11 // 函数定义
12 int func(int a, int b) {
13     static int m = 0, i = 2;
14     i += m + 1;
15     m = i + a + b;
16     return m;
17 }

1.首先在p1中,i=2+0+1=3,m=i+a+b=3+1+4=8

2.之后函数外面的m还是1,k还是4,但是函数里面的m是8,i是3

3.p2中,i=i+m+1=3+8+1=12,m=i+a+b=12+1+4=17

总结:局部static变量可在整个代码中循环,但是作用域只局限在局部

 

 

 

task3

 1 #include <stdio.h>
 2 long long func(int n); // 函数声明
 3 int main() {
 4     int n;
 5     long long f;
 6     while (scanf("%d", &n) != EOF) {
 7         f = func(n); // 函数调用
 8         printf("n = %d, f = %lld\n", n, f);
 9     }
10     return 0;
11 }
12 
13 long long func(int n) {
14     long long sum = 1;
15     if (n == 1) {
16         sum = 1;
17     }
18     else if (n > 1) {
19         sum = 2 * func(n - 1) + 1;
20     }
21     return sum;
22 }

 

 

 

 task4

1.迭代:

 1 #include <stdio.h>
 2 int func(int n, int m);
 3 int main() {
 4     int n, m;
 5     while (scanf("%d%d", &n, &m) != EOF)
 6         printf("n = %d, m = %d, ans = %d\n", n, m, func(n, m));
 7     return 0;
 8 }
 9 
10 int func(int n, int m) {
11     int sum1 = 1;
12     int sum2 = 1;
13     int sum3 = 1;
14 
15     int s = n - m;
16     if (s < 0) {
17         return 0;
18     }
19 
20     for (n; n > 0; n--) {
21         sum1 *= n;
22     }
23 
24     for (m; m > 0; m--) {
25         sum2 *= m;
26     }
27 
28     for (s; s > 0; s--) {
29         sum3 *= s;
30     }
31 
32     int sum = sum1 / (sum2 * sum3);
33 
34     return sum;
35     
36 }

2.递归

 1 #include <stdio.h>
 2 int func(int n, int m);
 3 int main() {
 4     int n, m;
 5     while (scanf("%d%d", &n, &m) != EOF)
 6         printf("n = %d, m = %d, ans = %d\n", n, m, func(n, m));
 7     return 0;
 8 }
 9 
10 int func(int n, int m) {
11     if (n < m) {
12         return 0;
13     }
14     int sum;
15     if (m == 0) {
16         return 1;
17     }
18     if (n == 1 && m == 1) {
19         sum = 1;
20     }
21     else if (m == 1) {
22         sum = n;
23     }
24     else {
25         sum = func(n - 1, m) + func(n - 1, m - 1);
26     }
27 
28     return sum;
29 }

两者结果一样:

 

 

 

task5

 1 #include <stdio.h>
 2 
 3 void move(int n, char A, char B, char C);
 4 
 5 int main()
 6 {
 7     int n;
 8     char A, B, C;
 9     while (scanf("%d", &n) != EOF) {
10         int step = 0;
11         move(n, 'A', 'B', 'C');
12         for (n; n > 0; n--) {
13             step = 2 * step + 1;
14         }
15         printf("\n");
16         printf("一共移动了%d次\n", step);
17         printf("\n");
18     }
19 
20     return 0;
21 }
22 
23 void move(int n, char A, char B, char C) {
24     if (n == 1) {
25         printf("%d:%c --> %c\n", n, A, C);
26     }
27     else {
28         move(n - 1, 'A', 'C', 'B');
29         printf("%d:%c --> %c\n", n, A, C);
30         move(n - 1, 'B', 'A', 'C');
31     }
32 }

tip:

三柱汉诺塔移动n个盘的步数是(n-1)盘的步数的2倍多1;

step(n)=2*step(n-1)+1;

 

 

 

 task6

 1 #include <stdio.h>
 2 #include <math.h>
 3 long func(long s); // 函数声明
 4 int main() {
 5     long s, t;
 6     printf("Enter a number: ");
 7     while (scanf("%ld", &s) != EOF) {
 8         t = func(s); // 函数调用
 9         t = func(t);
10         printf("new number is: %ld\n\n", t);
11         printf("Enter a number: ");
12     }
13     return 0;
14 }
15 
16 long func(long s) {
17     int n;
18     long sum = 0;
19     while (s > 0) {
20         n = s % 10;
21         if (n % 2 != 0) {
22             sum = sum * 10 + n;
23         }
24         s /= 10;
25     }
26 
27     return sum;
28 }

 

 

 

task7

  1 #include <stdio.h>
  2 int func(int n, int m);
  3 int main()
  4 {
  5     int n = 1;
  6     int flag = 0;
  7     while (flag == 0) {
  8         int n2 = n * n;
  9         int n3 = n * n * n;
 10         flag = func(n2, n3);
 11         if (flag == 1) {
 12             printf("result=%d\n", n);
 13             printf("它的平方是%d*%d=%d\n", n, n, n2);
 14             printf("它的立方是%d*%d*%d=%d\n", n, n, n, n3);
 15             return 0;
 16         }
 17         else {
 18             n++;
 19             continue;
 20         }
 21     }
 22     return 0;
 23 }
 24 
 25 int func(int n, int m) {
 26     int k = 0;
 27     int s;
 28     int jugde[10];
 29     for (s = 0; s < 10; s++) {
 30         jugde[s] = 1;
 31     }
 32     while (n > 0) {
 33         s = n % 10;
 34         switch (s) {
 35         case 0:
 36             jugde[s]--;
 37             break;
 38         case 1:
 39             jugde[s]--;
 40             break;
 41         case 2:
 42             jugde[s]--;
 43             break;
 44         case 3:
 45             jugde[s]--;
 46             break;
 47         case 4:
 48             jugde[s]--;
 49             break;
 50         case 5:
 51             jugde[s]--;
 52             break;
 53         case 6:
 54             jugde[s]--;
 55             break;
 56         case 7:
 57             jugde[s]--;
 58             break;
 59         case 8:
 60             jugde[s]--;
 61             break;
 62         case 9:
 63             jugde[s]--;
 64             break;
 65         }    
 66         n /= 10;
 67     }
 68     while (m > 0) {
 69         s = m % 10;
 70         switch (s) {
 71         case 0:
 72             jugde[s]--;
 73             break;
 74         case 1:
 75             jugde[s]--;
 76             break;
 77         case 2:
 78             jugde[s]--;
 79             break;
 80         case 3:
 81             jugde[s]--;
 82             break;
 83         case 4:
 84             jugde[s]--;
 85             break;
 86         case 5:
 87             jugde[s]--;
 88             break;
 89         case 6:
 90             jugde[s]--;
 91             break;
 92         case 7:
 93             jugde[s]--;
 94             break;
 95         case 8:
 96             jugde[s]--;
 97             break;
 98         case 9:
 99             jugde[s]--;
100             break;
101         }
102         m /= 10;
103     }
104     for (s = 0; s < 10; s++) {
105         if (jugde[s] != 0) {
106             k = 0;
107             break;
108         }
109         else {
110             k = 1;
111         }
112     }
113     return k;
114 }

 

posted @ 2023-10-30 16:06  VitaminC++  阅读(90)  评论(0编辑  收藏  举报