1、 写一个程序包括2个函数main和f: main:定义二维字符数组,输入字符串到第0行,将二维数组的首地址和指定字符作为f函数的实参,调用f函数,并输出第1行。 f:删除二维数组的第0行中的指定字符,并将结果存入二维数组的第1行。 f函数的原型: void f(char (*p)[20], char c) 测试用例:1) 输入:“ *he*l**lo*”,'*', 输出:“ hello”; 2) 输入:“ $I d$o$” , '$',输出:“ I do”; 2、写一个程序,定义以下结构类型,调用函数创建一个动态链表,并且输出该链表。 struct Student { int num; char name[20]; float score[3]; struct Student * next; }; 并且通过调用函数实现链表的创建,插入,打印等功能 测试用例:程序执行,提示请用户输入学生数据, 用户输入: 1 zhang 70 80 90回车, 程序执行,提示请用户输入结点数据, 用户输入: 2 li 70 80 90回车, 程序执行,提示请用户输入结点数据, 用户输入: 3 wang 70 80 90回车, 程序执行,提示请用户输入结点数据, 用户输入: 0 0 0 0 0回车, 程序输出: 1, zhang, 70.00, 80.00, 90.00, 2, li, 70.00, 80.00, 90.00, 3, wang, 70.00, 80.00, 90.00
时间: 2023-01-28 19:31:59 浏览: 119
C语言中二维数组作为函数参数来传递的三种方法
5星 · 资源好评率100%
第一个问题的程序如下:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 定义 f 函数,用于在二维字符数组的第 0 行中删除指定字符,并将结果存入二维数组的第 1 行
void f(char (*p)[20], char c) {
int i = 0, j = 0;
// 遍历第 0 行的所有字符
while ((*p)[i] != '\0') {
// 如果当前字符不是指定字符,就将其存入第 1 行
if ((*p)[i] != c) {
(*p)[j] = (*p)[i];
j++;
}
i++;
}
// 在第 1 行的末尾加入空字符
(*p)[j] = '\0';
}
int main() {
char array[2][20]; // 定义二维字符数组
// 输入字符串到第 0 行
printf("请输入字符串:");
scanf("%s", array[0]);
// 调用 f 函数,将二维数组的首地址和指定字符作为实参
printf("请输入要删除的字符:");
char c;
scanf(" %c", &c);
f(array, c);
// 输出第 1 行
printf("第 1 行:%s\n", array[1]);
return 0;
}
第二个问题的程序如下:
#include <stdio.h>
#include <stdlib.h>
// 定义学生结构体类型
struct Student {
int num;
char name[20];
float score[3];
struct Student *next;
};
// 定义函数,用于创建动态链表
struct Student *create_list() {
struct Student *p, *q, *head;
head = NULL;
printf("请输
阅读全文