books* books_delete(books* head) { int id; books* p, * q; p = head; printf("请输入你的序列号:"); scanf("%d", &id); if (p->id == id) { head = p->next; free(p); } else { while (p->next) { q = p->next; if (q->id == id) { p->next = q->next; free(q); break; } p = p->next; } } return head; }还是删除不了第一本书?
时间: 2024-03-24 22:35:41 浏览: 22
这段代码中的问题可能在于,头节点为空时,删除操作会出现错误,因为在删除头节点之前,需要判断头节点是否为空。
以下是修改后的代码:
```
books* books_delete(books* head) {
int id;
books* p, * q;
p = head;
printf("请输入你的序列号:");
scanf("%d", &id);
if (p == NULL) {
printf("链表为空!");
return head;
}
if (p->id == id) {
head = p->next;
free(p);
}
else {
while (p->next) {
q = p->next;
if (q->id == id) {
p->next = q->next;
free(q);
break;
}
p = p->next;
}
}
return head;
}
```
在修改后的代码中,我们添加了对头节点为空的判断,并且在删除第一本书时也正确处理了头指针的变化。
相关问题
void books_delete(books* head) { int id; books* p, * q; p = q = (books*)malloc(LEN); p = head; printf("请输入你的序列号:"); scanf("%d", &id); if (p->id == id) { p->next = p->next->next; free(p); } else { q = p->next; p->next = p->next->next; } return head; }为什么删除不了第一本书?
这段代码中的问题在于删除第一本书时没有正确处理头指针。如果要删除第一本书,则应该将头指针移动到第二本书,而不是直接删除第一本书。可以参考以下修改后的代码:
```
books* books_delete(books* head) {
int id;
books* p, * q;
p = head;
printf("请输入你的序列号:");
scanf("%d", &id);
if (p->id == id) {
head = p->next;
free(p);
}
else {
while (p->next) {
q = p->next;
if (q->id == id) {
p->next = q->next;
free(q);
break;
}
p = p->next;
}
}
return head;
}
```
在这个修改后的代码中,我们通过修改头指针的方式来删除第一本书。并且在删除其他书籍时,我们使用了 while 循环来查找要删除的书籍,然后将其从链表中删除。
books* creat() { books* h; books* head; books* p1, * p2; int n = 0; int w; p1=(books*)malloc(LEN); printf("\tt\t我们先创建图书表\n\n"); printf("请输入序列号:"); scanf("%d", &p1->id); printf("请输入年份:"); scanf("%d", &p1->year); printf("请输入作者:"); scanf("%s", &p1->author); printf("请输入书名:"); scanf("%s", &p1->name); head = p1; head->next = NULL; printf("\n\n请按下面数字选择:\n\n"); printf(" 1.继续 2.结束"); printf("\n请选择:"); scanf("%d", &w); p2 = head; while (w == 1) { p1 = (books*)malloc(LEN); printf("请输入序列号:"); scanf("%d", &p1->id); printf("请输入日期:"); scanf("%d", &p1->year); printf("请输入作者:"); scanf("%s", &p1->author); printf("请输入书名:"); scanf("%s", &p1->name); p2->next = p1; p1->next = NULL; p2 = p2->next; printf("\n\n请按下面数字选择:\n\n"); printf(" 1.继续 2.结束"); printf("\n请选择:\n"); scanf("%d", &w); } return head; }要怎么删除第一本书?
要删除第一本书,需要进行以下操作:
1. 定义一个临时指针变量temp,将其指向头结点的下一个节点。
2. 释放头结点内存空间,即调用free(head)。
3. 将头结点指针head指向temp,即head = temp。
4. 返回头结点指针head。
以下是修改后的代码:
```
books* delete_first_book(books* head) {
if (head == NULL) {
printf("空链表,无法删除!\n");
return head;
}
books* temp = head->next;
free(head);
head = temp;
return head;
}
```
调用该函数即可删除第一本书,如下所示:
```
head = delete_first_book(head);
```
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)