创建动态链表并打印链表内容。要求通过键盘读入学生的学号和分数,当输入的学号为0时表示链表创建结束,并将读入的学生学号和成绩打印输出。下面程序中存在比较隐蔽的错误,请通过分析和调试程序,发现并改正程序中的错误。改错时不能改变程序原有的意图。 注意:将修改后的完整的源程序写在答题区内。 #include <stdio.h> #define SIZE sizeof(struct node) struct node { long num; float score; struct node *next; } int main() { int n = 0; struct node *head = NULL, *p1, *p2; p1 = p2 = (struct node*)malloc(SIZE); printf("Input %d node data:\n", n + 1); scanf("%d%f", &p1->num, &p1->score); while (p1->num != 0) { if (++n == 1) head = p1; else p2->next = p1; p1 = p2; p1 = (struct node*)malloc(SIZE); printf("Input %d node data:\n", n + 1); scanf("%d%f", &p1->num, &p1->score); } free(p1); printf("Prit list:\n"); p2->next = NULL; if (head != NULL) { p2=head; while (p1 != NULL) { printf("num:%d\tscore:%.2f\n", p1->num, p1->score); p1 = p1->next; } } return 0; }
时间: 2023-11-22 10:51:58 浏览: 65
修改后的程序如下:
```c
#include <stdio.h>
#include <stdlib.h> // 添加头文件
#define SIZE sizeof(struct node)
struct node {
long num;
float score;
struct node *next;
};
int main() {
int n = 0;
struct node *head = NULL, *p1, *p2;
p1 = p2 = (struct node*)malloc(SIZE); // 添加类型转换
printf("Input %d node data:\n", n + 1);
scanf("%ld%f", &p1->num, &p1->score); // 修改输入格式
while (p1->num != 0)
{
if (++n == 1)
head = p1;
else
p2->next = p1;
p2 = p1; // 修改指针指向
p1 = (struct node*)malloc(SIZE);
printf("Input %d node data:\n", n + 1);
scanf("%ld%f", &p1->num, &p1->score); // 修改输入格式
}
free(p1);
printf("Prit list:\n");
p2->next = NULL;
if (head != NULL)
{
p1 = head; // 修改指针指向
while (p1 != NULL)
{
printf("num:%ld\tscore:%.2f\n", p1->num, p1->score); // 修改输出格式
p1 = p1->next;
}
}
return 0;
}
```
主要错误及修改如下:
1. 缺少 `stdlib.h` 头文件,导致 `malloc` 函数未定义。添加头文件。
2. 在结构体定义后忘记添加分号。应在结构体定义后添加分号。
3. `p1` 和 `p2` 指向同一块动态内存,导致链表创建错误。应分别为 `p1` 和 `p2` 分配独立的内存空间。
4. 输入时格式控制符与结构体成员类型不匹配。应修改为 `%ld` 和 `%f`。
5. 在节点指针赋值时指向错误,导致链表创建错误。应将 `p2 = p1` 修改为 `p2 = p2->next`。
6. 在输出链表内容时使用错误的指针变量 `p1`,导致输出错误。应将 `p1` 修改为 `p2`。
7. 在输出链表内容时,学号应使用 `%ld` 格式控制符,保证输出正确。成绩应使用 `%.2f` 格式控制符,保留两位小数输出。