实验五

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

运行截图
image

实验任务1

问题1:函数find-min-max的功能是找出数组中的最小值和最大值,用指针指向其地址

问题2:都指向x[0]所在地址

实验任务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

实验任务2.1

问题回答

1.s1的大小是80,sizeof计算的是s1的大小,strlen计算的是s1中字符的有效长度

2.不能替换,地址常量不能改变

3.s1和s2的内容发生了交换

代码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

运行截图

实验任务2.2

回答问题

1:字符串的地址;指针变量的大小;字符串的长度

2:可以,定义的是指向字符串的指针变量, 1中s1是数组首地址常量 , 2中s1是一个指针常量

3.指针方向发生了交换,字符串常量在内存中不发生交换

实验任务3

源代码

1 #include <stdio.h>
2 #include <stdlib.h>
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
20 if ((i + 1) % 4 == 0)
21 printf("\n");
22 }
23
24 printf("\n输出3: 使用指针变量ptr2(指向一维数组)访问\n");
25 for (ptr2 = x; ptr2 < x + 2; ++ptr2) {
26 for (j = 0; j < 4; ++j)
27 printf("%d ", (ptr2 + j));
28 printf("\n");
29 }
30 system("pause");
31 return 0;
32 }

运行截图
image

实验任务3

回答问题

1:ptr是一个指针,指向包含4个int类型元素的一维数组

2:.ptr是一个包含4个int*类型元素的数组

实验任务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 // 函数定义
21 void replace(char str, char old_char, char new_char) {
22 int i;
23
24 while(
str) {
25 if(*str == old_char)
26 *str = new_char;
27 str++;
28 }
29 }

运行截图
image

实验任务4

回答问题:

1:将字符串中的所有旧的字符替换成新字符

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
21 return 0;
22 }
23
24 // 函数str_trunc定义
25 // 功能: 对字符串作截断处理,把指定字符自第一次出现及其后的字符全部删除, 并返回字符串地址
26 char *str_trunc(char *str, char x) {
27 char p = str;
28 while (
p && *p != x) {
29 p++;
30 }
31 *p = '\0';
32 return str;
33 }

运行截图

实验任务5
image

回答问题:

1.输入回车残留换行符\n会被下一轮getchar()读取,误把换行当作截断字符,导致提前错误截断字符串;吸收输入完字符后按下的回车换行符\n

实验任务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 for (i = 0; i < N; i++)
16 if (check_id(pid[i])) // 函数调用
17 printf("%s\tTrue\n", pid[i]);
18 else
19 printf("%s\tFalse\n", pid[i]);
20 return 0;
21 }
22
23
24 int check_id(char str)
25 {
26
27 if(strlen(str) != 18)
28 return 0;
29
30 for(int i = 0; i < 18; i++)
31 {
32 if(i == 17)
33 {
34 if(!((
(str+i)>='0'&&
(str+i)<='9') || (str+i)=='X'))
35 return 0;
36 }
37 else
38 {
39 if(!(
(str+i)>='0' && *(str+i)<='9'))
40 return 0;
41 }
42 }
43 return 1;
44 }
复制代码
运行截图
image

实验任务7

源代码

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

实验任务7

实验任务7.1

实验任务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 for (i = 1; i < argc - 1; i++) {
8 for (j = i + 1; j < argc; j++) {
9 if (strcmp(argv[i], argv[j]) > 0) {
10 temp = argv[i];
11 argv[i] = argv[j];
12 argv[j] = temp;
13 }
14 }
15 }
16 for (i = 1; i < argc; i++) {
17 printf("hello, %s\n", argv[i]);
18 }
19 return 0;
20 }

运行截图

实验任务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 for (i = 1; i < argc - 1; i++) {
8 for (j = i + 1; j < argc; j++) {
9 if (strcmp(argv[i], argv[j]) > 0) {
10 temp = argv[i];
11 argv[i] = argv[j];
12 argv[j] = temp;
13 }
14 }
15 }
16 for (i = 1; i < argc; i++) {
17 printf("hello, %s\n", argv[i]);
18 }
19 return 0;
20 }
复制代码
运行截图
image

posted @ 2026-06-15 18:11  种野菜  阅读(4)  评论(0)    收藏  举报