实验5

实验任务1

源代码1

 1 #include <stdio.h>
 2 #define N 5
 3 void input(int x[], int n);
 4 void output(int x[], int n);
 5 void find_min_max(int x[], int n, int *pmin, int *pmax);
 6 
 7 int main() {
 8     int a[N];
 9     int min, max;
10 
11     printf("录入%d个数据\n", N);
12     input(a, N);
13 
14     printf("数据是:\n");
15     output(a, N);
16 
17     printf("数据处理...\n");
18     find_min_max(a, N, &min, &max);
19 
20     printf("输出结果:\n");
21     printf("min = %d, max = %d\n", min, max);
22 
23     return 0;
24 }
25 
26 void input(int x[], int n) {
27     int i;
28     for(i = 0; i < n; ++i)
29         scanf("%d", &x[i]);
30 }
31 
32 void output(int x[], int n) {
33     int i;
34     for(i = 0; i < n; ++i)
35         printf("%d ", x[i]);
36     printf("\n");
37 }
38 
39 void find_min_max(int x[], int n, int *pmin, int *pmax) {
40     int i;
41     *pmin = *pmax = x[0];
42     for(i = 0; i < n; ++i)
43         if(x[i] < *pmin)
44             *pmin = x[i];
45         else if(x[i] > *pmax)
46             *pmax = x[i];
47 }

运行结果截图

image

问题回答

1.找出数组中的最小值与最大值。

2.pmin指向主函数中变量 min 的内存地址,pmax 指向主函数中变量 max的内存地址。

源代码2

 1 #include <stdio.h>
 2 #define N 5
 3 void input(int x[], int n);
 4 void output(int x[], int n);
 5 int *find_max(int [], int n);
 6 
 7 int main() {
 8     int a[N];
 9     int *pmax;
10 
11     printf("录入%d个数据\n", N);
12     input(a, N);
13 
14     printf("数据是:\n");
15     output(a, N);
16 
17     printf("数据处理...\n");
18     pmax = find_max(a, N);
19 
20     printf("输出结果:\n");
21     printf("max = %d\n", *pmax);
22 
23     return 0;
24 }
25 
26 void input(int x[], int n) {
27     int i;
28     for(i = 0; i < n; ++i)
29         scanf("%d", &x[i]);
30 }
31 
32 void output(int x[], int n) {
33     int i;
34     for(i = 0; i < n; ++i)
35         printf("%d ", x[i]);
36     printf("\n");
37 }
38 
39 int *find_max(int x[], int n) {
40     int max_index = 0;
41     int i;
42     for(i = 0; i < n; ++i)
43         if(x[i] > x[max_index])
44             max_index = i;
45     return &x[max_index];
46 }

运行结果截图

image

问题回答

1.查找数组中最大值所在的元素;

   返回数组中最大值元素的内存地址。

2.可以。

实验任务2

源代码1

 1 #include <stdio.h>
 2 #include <string.h>
 3 #define N 80
 4 
 5 int main() {
 6     char s1[N] = "Learning makes me happy";
 7     char s2[N] = "Learning makes me sleepy";
 8     char tmp[N];
 9 
10     printf("sizeof(s1) vs. strlen(s1): \n");
11     printf("sizeof(s1) = %d\n", sizeof(s1));
12     printf("strlen(s1) = %d\n", strlen(s1));
13 
14     printf("\nbefore swap: \n");
15     printf("s1: %s\n", s1);
16     printf("s2: %s\n", s2);
17 
18     printf("\nswapping...\n");
19     strcpy(tmp, s1);
20     strcpy(s1, s2);
21     strcpy(s2, tmp);
22 
23     printf("\nafter swap: \n");
24     printf("s1: %s\n", s1);
25     printf("s2: %s\n", s2);
26 
27     return 0;
28 }

运行结果截图

image

问题回答

1.80 字节;

   计算整个字符数组占用的内存总字节数;

   统计字符串中有效字符的个数(不包含末尾 '\0' 结束符)。

2.不能替换;
   s1是数组名,属于地址常量,数组名不能被重新赋值,因此不能直接用字符串常量对数组名赋值。

3.交换。

源代码2

 1 #include <stdio.h>
 2 #include <string.h>
 3 #define N 80
 4 
 5 int main() {
 6     char *s1 = "Learning makes me happy";
 7     char *s2 = "Learning makes me sleepy";
 8     char *tmp;
 9 
10     printf("sizeof(s1) vs. strlen(s1): \n");
11     printf("sizeof(s1) = %d\n", sizeof(s1));
12     printf("strlen(s1) = %d\n", strlen(s1));
13 
14     printf("\nbefore swap: \n");
15     printf("s1: %s\n", s1);
16     printf("s2: %s\n", s2);
17 
18     printf("\nswapping...\n");
19     tmp = s1;
20     s1 = s2;
21     s2 = tmp;
22 
23     printf("\nafter swap: \n");
24     printf("s1: %s\n", s1);
25     printf("s2: %s\n", s2);
26 
27     return 0;
28 }

运行结果截图

image

问题回答

1.字符串常量在内存中的首地址;

   指针变量本身占用的内存字节数(32 位系统为 4 字节,64 位系统为 8 字节);

   指针指向的字符串的有效字符个数,不包含末尾\0。

2.可以;

   一个是字符数组初始化,另一个是指针赋值。

3.两个指针变量中存储的地址值;

   没交换。

实验任务3

源代码

 1 #include <stdio.h>
 2 
 3 int main() {
 4     int x[2][4] = {{1, 9, 8, 4}, {2, 0, 4, 9}};
 5     int i, j;
 6     int *ptr1;        // 指针变量,存放int类型数据的地址
 7     int (*ptr2)[4];   // 指针变量,指向包含4个int元素的一维数组
 8 
 9     printf("输出1: 使用数组名、下标直接访问二维数组元素\n");
10     for (i = 0; i < 2; ++i) {
11         for (j = 0; j < 4; ++j)
12             printf("%d ", x[i][j]);
13         printf("\n");
14     }
15 
16     printf("\n输出2: 使用指针变量ptr1(指向元素)访问\n");
17     for (ptr1 = &x[0][0], i = 0; ptr1 < &x[0][0] + 8; ++ptr1, ++i) {
18         printf("%d ", *ptr1);
19         if ((i + 1) % 4 == 0)
20             printf("\n");
21     }
22 
23     printf("\n输出3: 使用指针变量ptr2(指向一维数组)访问\n");
24     for (ptr2 = x; ptr2 < x + 2; ++ptr2) {
25         for (j = 0; j < 4; ++j)
26             printf("%d ", *(*ptr2 + j));
27         printf("\n");
28     }
29 
30     return 0;
31 }

运行结果截图

image

问题回答

1.ptr 是数组指针。

2.ptr 是指针数组。

实验任务4

源代码

 1 #include <stdio.h>
 2 #define N 80
 3 
 4 void replace(char *str, char old_char, char new_char); 
 5 
 6 int main() {
 7     char text[N] = "Programming is difficult or not, it is a question.";
 8 
 9     printf("原始文本:\n");
10     printf("%s\n", text);
11 
12     replace(text, 'i', '*'); 
13 
14     printf("处理后文本:\n");
15     printf("%s\n", text);
16 
17     return 0;
18 }
19 
20 void replace(char *str, char old_char, char new_char) {
21     int i;
22     while(*str) {
23         if(*str == old_char)
24             *str = new_char;
25         str++;
26     }
27 }

运行结果截图

image

问题回答

1.将字符串中所有等于 old_char的字符,全部替换为 new_char。

2.可以。

实验任务5

源代码

 1 #include <stdio.h>
 2 #define N 80
 3 
 4 char *str_trunc(char *str, char x);
 5 
 6 int main() {
 7     char str[N];
 8     char ch;
 9 
10     while(printf("输入字符串中: "), gets(str) != NULL) {
11         printf("输入一个字符: ");
12         ch = getchar();
13 
14         printf("截断处理...\n");
15         str_trunc(str, ch);        
16 
17         printf("截断处理后的字符串: %s\n\n", str);
18         getchar();
19     }
20     return 0;
21 }
22 
23 char *str_trunc(char *str, char x) {
24     while (*str != '\0' && *str != x) {
25         str++;
26     }
27     
28     *str = '\0';
29     
30     return str;
31 }

运行结果截图

image

问题回答

程序无法连续正常输入多组数据。第二次后会跳过下一轮的字符串输入,直接读取换行符,导致无法正常连续多组测试;

清理输入缓冲区里的回车换行符 \n,防止下一次 gets 误读取这个空行,保证多组输入正常执行。

实验任务6

源代码

 1 #include <stdio.h>
 2 #include <string.h>
 3 #define N 5
 4 
 5 int check_id(char *str); 
 6 
 7 int main()
 8 {
 9     char *pid[N] = {"31010120000721656X",
10                     "3301061996X0203301",
11                     "53010220051126571",
12                     "510104199211197977",
13                     "53010220051126133Y"};
14     int i;
15 
16     for (i = 0; i < N; ++i)
17         if (check_id(pid[i])) 
18             printf("%s\tTrue\n", pid[i]);
19         else
20             printf("%s\tFalse\n", pid[i]);
21 
22     return 0;
23 }
24 
25 int check_id(char *str) {
26     int len = strlen(str);
27     if(len != 18) {
28         return 0;
29     }
30     
31     char *p = str;
32     for(int i = 0; i < 18; i++) {
33         if(i < 17) {
34             if(*p < '0' || *p > '9') {
35                 return 0;
36             }
37         }
38         
39         else {
40             if(!( (*p >= '0' && *p <= '9') || *p == 'X' )) {
41                 return 0;
42             }
43         }
44         p++;
45     }
46     
47     return 1;
48 }

运行结果截图

image

实验任务7

源代码

 1 #include <stdio.h>
 2 #define N 80
 3 void encoder(char *str, int n); 
 4 void decoder(char *str, int n); 
 5 
 6 int main() {
 7     char words[N];
 8     int n;
 9     printf("输入英文文本: ");
10     gets(words);
11     printf("输入n: ");
12     scanf("%d", &n);
13 
14     printf("编码后的英文文本: ");
15     encoder(words, n);    
16     printf("%s\n", words);
17 
18     printf("对编码后的英文文本解码: ");
19     decoder(words, n);   
20     printf("%s\n", words);
21 
22     return 0;
23 }
24 
25 void encoder(char *str, int n) {
26     while (*str != '\0') {
27         if (*str >= 'a' && *str <= 'z') {
28             *str = (*str - 'a' + n) % 26 + 'a';
29         }
30         else if (*str >= 'A' && *str <= 'Z') {
31             *str = (*str - 'A' + n) % 26 + 'A';
32         }
33         str++;
34     }
35 }
36 
37 void decoder(char *str, int n) {
38     while (*str != '\0') {
39         if (*str >= 'a' && *str <= 'z') {
40             *str = (*str - 'a' - n + 26) % 26 + 'a';
41         }
42         else if (*str >= 'A' && *str <= 'Z') {
43             *str = (*str - 'A' - n + 26) % 26 + 'A';
44         }
45         str++;
46     }
47 }

运行结果截图

image

image

image

实验任务8

源代码

 1 #include <stdio.h>
 2 #include <string.h>
 3 
 4 int main(int argc, char *argv[]) {
 5     int i,j;
 6     char *temp;
 7 
 8     for(i = 1; i < argc-1; ++i){
 9          for(j = 1; j < argc-1-i; ++j){
10              if(strcmp (argv[j],argv[j+1])>0){
11                  temp = argv[j];
12                  argv[j] = argv[j+1];
13                  argv[j+1] = temp;
14              }
15          }
16     }
17 
18         for(i = 1; i < argc; ++i)
19             printf("hello, %s\n", argv[i]);
20     return 0;
21 }

运行结果截图

image

posted @ 2026-06-02 22:13  X++++++++++++  阅读(6)  评论(0)    收藏  举报