急求关于链表程序的问题
时间:2010-07-20
来源:互联网
这一段时间在研究链表,写了个单链表翻转的例子,可是只输出了一个值,调试发现,内存地址正确,可就是在next却变为了0x0,不能访问。
贴代码:
复制代码
求各位高手帮忙解答,小弟先谢谢了。
贴代码:
- #include<stdio.h>
- #include<stdlib.h>
-
- typedef struct stu{
- int data;
- struct stu *next;
- }student;
-
- student *head = NULL;
-
- student *insert(student **p,int data)
- {
- student *new = malloc(sizeof(student));
- new->data = data;
-
- new->next = *p;
- *p = new;
-
- return *p;
- }
- void output(student *p)
- {
- int i = 0;
- while(p)
- {
- printf("%d:%d\n",++i,p->data);
- p = p->next;
- }
- }
- student *reverse(student *pre,student *p) //反转程序,应该没什么问题
- {
- if(!p)
- return NULL;
- if(!p->next)
- {
- p->next = pre;
- return p;
- }
- else
- {
- student *first;
- first = reverse(pre,p->next);
- p->next = pre;
- return first;
- }
- }
- int main(void)
- {
- insert(&head,12);
- insert(&head,28);
- insert(&head,10);
- insert(&head,17);
-
-
- student *p = reverse(NULL,head); //调试的时候,display p->next 就显示内存无法访问,返回是first地址
-
- output(p); //这里只输出了12,应该可以继续向下走,循环输出,可是p->next就不能访问了
-
- return 0;
- }
- #include<stdio.h>
- #include<stdlib.h>
-
- typedef struct stu{
- int data;
- struct stu *next;
- }student;
-
- student *head = NULL;
-
- student *insert(student **p,int data)
- {
- student *new = malloc(sizeof(student));
- new->data = data;
-
- new->next = *p;
- *p = new;
-
- return *p;
- }
- void output(student *p)
- {
- int i = 0;
- while(p)
- {
- printf("%d:%d\n",++i,p->data);
- p = p->next;
- }
- }
- student *reverse(student *pre,student *p) //反转程序,应该没什么问题
- {
- if(!p)
- return NULL;
- if(!p->next)
- {
- p->next = pre;
- return p;
- }
- else
- {
- student *first;
- first = reverse(pre,p->next);
- p->next = pre;
- return first;
- }
- }
- int main(void)
- {
- insert(&head,12);
- insert(&head,28);
- insert(&head,10);
- insert(&head,17);
-
-
- student *p = reverse(NULL,head); //调试的时候,display p->next 就显示内存无法访问,返回是first地址
-
- output(p); //这里只输出了12,应该可以继续向下走,循环输出,可是p->next就不能访问了
-
- return 0;
- }
作者: jasfidfjds 发布时间: 2010-07-20
insert()为啥要传个二级指针。小心把header的地址给改变了。
一般的链表没有这么写的吧。
你可以用gdb调适下。
一般的链表没有这么写的吧。
你可以用gdb调适下。
作者: 怪怪虎 发布时间: 2010-07-20
翻转函数有问题,你要返回值设错了。 而且递归实现会变成循环链表 所以要传2级指针。
这里有一个循环实现的翻转。
复制代码
这里有一个循环实现的翻转。
- void reverse(student **h)
- {
- if( *h == NULL)
- return ;
- student *pre, *cur, *next;
-
- pre = *h;
- cur = (*h)->next;
- while(cur)
- {
- next = cur->next;
- cur->next = pre;
- pre = cur;
- cur = next;
- }
- (*h)->next = NULL;
- *h = pre;
- }
作者: peijue 发布时间: 2010-07-20
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28