实验五
任务1
1.1
代码
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 for(i = 0; i < n; ++i) 30 scanf("%d", &x[i]); 31 } 32 33 void output(int x[], int n) { 34 int i; 35 for(i = 0; i < n; ++i) 36 printf("%d ", x[i]); 37 printf("\n"); 38 } 39 40 void find_min_max(int x[], int n, int *pmin, int *pmax) { 41 int i; 42 *pmin = *pmax = x[0]; 43 for(i = 0; i < n; ++i) 44 if(x[i] < *pmin) 45 *pmin = x[i]; 46 else if(x[i] > *pmax) 47 *pmax = x[i]; 48 }
运行结果
问题1 找到5个数中的最大值和最小值
问题2 pmin和pmax都指向数组元素x[0]的地址
1.2
代码
1 #include <stdio.h> 2 #define N 5 3 4 void input(int x[], int n); 5 void output(int x[], int n); 6 int *find_max(int x[], int n); 7 8 int main() { 9 int a[N]; 10 int *pmax; 11 12 printf("录入%d个数据:\n", N); 13 input(a, N); 14 15 printf("数据是: \n"); 16 output(a, N); 17 18 printf("数据处理...\n"); 19 pmax = find_max(a, N); 20 21 printf("输出结果:\n"); 22 printf("max = %d\n", *pmax); 23 24 return 0; 25 } 26 27 void input(int x[], int n) { 28 int i; 29 for(i = 0; i < n; ++i) 30 scanf("%d", &x[i]); 31 } 32 33 void output(int x[], int n) { 34 int i; 35 for(i = 0; i < n; ++i) 36 printf("%d ", x[i]); 37 printf("\n"); 38 } 39 40 int *find_max(int x[], int n) { 41 int max_index = 0; 42 int i; 43 for(i = 0; i < n; ++i) 44 if(x[i] > x[max_index]) 45 max_index = i; 46 return &x[max_index]; 47 }
问题1 返回的是最大值数组的元素
问题2 可以 这里用指针变量代替了数组元素的地址
任务2
2.1
代码
#include <stdio.h> #include <string.h> #define N 80 int main() { char s1[N] = "Learning makes me happy"; char s2[N] = "Learning makes me sleepy"; char tmp[N]; printf("sizeof(s1) vs. strlen(s1): \n"); printf("sizeof(s1) = %d\n", sizeof(s1)); printf("strlen(s1) = %d\n", strlen(s1)); printf("\nbefore swap: \n"); printf("s1: %s\n", s1); printf("s2: %s\n", s2); printf("\nswapping...\n"); strcpy(tmp, s1); strcpy(s1, s2); strcpy(s2, tmp); printf("\nafter swap: \n"); printf("s1: %s\n", s1); printf("s2: %s\n", s2); return 0; }
运行结果
问题1 s1大小为80 sizeof计算数组s1在1内存中所占字节数strlen
问题2 不能 因为s1指向s1数组的s1[0]的地址 而该操作修改了该地址
问题3 是
2.2
#include <stdio.h> #include <string.h> #define N 80 #include<stdlib.h> int main() { char *s1 = "Learning makes me happy"; char *s2 = "Learning makes me sleepy"; char *tmp; printf("sizeof(s1) vs. strlen(s1): \n"); printf("sizeof(s1) = %d\n", sizeof(s1)); printf("strlen(s1) = %d\n", strlen(s1)); printf("\nbefore swap: \n"); printf("s1: %s\n", s1); printf("s2: %s\n", s2); printf("\nswapping...\n"); tmp = s1; s1 = s2; s2 = tmp; printf("\nafter swap: \n"); printf("s1: %s\n", s1); printf("s2: %s\n", s2); system("pause"); return 0; }
运行结果
问题1 s1存放字符串首个字符l的地址 sizeof计算首个字符地址大小strlen计算字符串中字符个数
问题2 可以
问题3 交换指针变量 没有
任务3
代码
#include <stdio.h> #include <stdlib.h> int main() { int x[2][4] = {{1, 9, 8, 4}, {2, 0, 4, 9}}; int i, j; int *ptr1; // 指针变量,存放int类型数据的地址 int (*ptr2)[4]; // 指针变量,指向包含4个int元素的一维数组 printf("输出1: 使用数组名、下标直接访问二维数组元素\n"); for (i = 0; i < 2; ++i) { for (j = 0; j < 4; ++j) printf("%d ", x[i][j]); printf("\n"); } printf("\n输出2: 使用指针变量ptr1(指向元素)间接访问\n"); for (ptr1 = &x[0][0], i = 0; ptr1 < &x[0][0] + 8; ++ptr1, ++i) { printf("%d ", *ptr1); if ((i + 1) % 4 == 0) printf("\n"); } printf("\n输出3: 使用指针变量ptr2(指向一维数组)间接访问\n"); for (ptr2 = x; ptr2 < x + 2; ++ptr2) { for (j = 0; j < 4; ++j) printf("%d ", *(*ptr2 + j)); printf("\n"); } system("pause"); return 0; }
运行结果
问题1 指行指针变量
问题2 指指针数组
任务4
代码
#include <stdio.h> #define N 80 void replace(char *str, char old_char, char new_char); // 函数声明 int main() { char text[N] = "Programming is difficult or not, it is a question."; printf("原始文本: \n"); printf("%s\n", text); replace(text, 'i', '*'); // 函数调用 注意字符形参写法, 单引号不能少 printf("处理后文本: \n"); printf("%s\n", text); return 0; } // 函数定义 void replace(char *str, char old_char, char new_char) { int i; while(*str) { if(*str == old_char) *str = new_char; str++; } }
运行结果
问题1 将i替换成*
问题2 可以
任务5
代码
#include <stdio.h> #define N 80 char *str_trunc(char *str, char x); int main() { char str[N]; char ch; while (printf("输入字符串: "), gets(str) != NULL) { printf("输入一个字符: "); ch = getchar(); printf("截断处理...\n"); str_trunc(str, ch); // 函数调用 printf("截断处理后的字符串: %s\n\n", str); getchar(); } return 0; } char *str_trunc(char *str, char x) { int i; for (i = 0; *str != '\0'; str++) if (*str == x) { *str = '\0'; break; } return str; }
运行结果
任务6
#include <stdio.h> #include <string.h> #define N 5 #include <stdlib.h> int check_id(char *str); // 函数声明 int main() { char *pid[N] = {"31010120000721656X", "3301061996X0203301", "53010220051126571", "510104199211197977", "53010220051126133Y"}; int i; for (i = 0; i < N; ++i) if (check_id(pid[i])) // 函数调用 printf("%s\tTrue\n", pid[i]); else printf("%s\tFalse\n", pid[i]); system("pause"); return 0; } int check_id(char *str) { int i; if (strlen(str) != 18) return 0; for (i = 0; i <= 16; i++) if (*(str + i) < '0' || *(str + i) > '9') return 0; if ((*(str + 17) >= '0' && *(str + 17) <= '9') || *(str + 17) == 'X') return 1; return 0; }
运行结果
任务7
代码
#include <stdio.h> #define N 80 #include <stdlib.h> #include <string.h> void encoder(char *str, int n); // 函数声明 void decoder(char *str, int n); // 函数声明 int main() { char words[N]; int n; printf("输入英文文本: "); gets(words); printf("输入n: "); scanf("%d", &n); printf("编码后的英文文本: "); encoder(words, n); // 函数调用 printf("%s\n", words); printf("对编码后的英文文本解码: "); decoder(words, n); // 函数调用 printf("%s\n", words); system("pause"); return 0; } /*函数定义 功能: 对s指向的字符串进行编码处理 编码规则: 对于a~z或A~Z之间的字母字符, 用其后第n个字符替换; 其它非字母字符, 保持不变 */ void encoder(char *str, int n) { int i; for(i = 0; *(str + i) != '\0'; ++i) { if(*(str + i) >= 'a' && *(str + i) <= 'z') *(str + i) = (*(str + i) - 'a' + n) % 26 + 'a'; if(*(str + i) >= 'A' && *(str + i) <= 'Z') *(str + i) = (*(str + i) - 'A' + n) % 26 + 'A'; } } /*函数定义 功能: 对s指向的字符串进行解码处理 解码规则: 对于a~z或A~Z之间的字母字符, 用其前面第n个字符替换; 其它非字母字符, 保持不变 */ void decoder(char *str, int n) { int i; for(i = 0; *(str + i) != '\0'; ++i) { if(*(str + i) >= 'a' && *(str + i) <= 'z') *(str + i) = ((*(str + i) - 'a' - n + 26) % 26) + 'a'; } }
运行结果
任务8
代码
#include <stdio.h> #include <string.h> int main(int argc, char *argv[]) { int i, j; char m; for(i = 0; i < argc - 1; ++i) for(j = 0; j <= i; ++j) if(strcmp(argv[j], argv[j + 1]) > 0 ) { m = *argv[j]; *argv[j] = *argv[j + 1]; *argv[j + 1] = m; } for(i = 0; i < argc; ++i) printf("hello, %s\n", argv[i]); return 0; }