免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: GAORJ
打印 上一主题 下一主题

如何实现一个单链表的反转?  关闭 [复制链接]

论坛徽章:
0
21 [报告]
发表于 2004-11-01 13:39 |只看该作者

如何实现一个单链表的反转?


  1. typedef        struct Node{
  2.         ElementType element;
  3.         Node *next;
  4. }Node;


  5. Node *ReverseList(Node *List){
  6.         Node *L;
  7.         int len;
  8.        
  9.         len = ListLen(List);//求出单向练表的长度
  10.          L = List;
  11.        
  12.          for( i = len; i >; 0; i-- ){ // 节点N指向节点N-1
  13.                  (L + i)->;next = (L + i -1)->;next;
  14.          }

  15.          L->;next = NULL;
  16.          return (L + len);
  17. }
  18.                  
复制代码

论坛徽章:
0
22 [报告]
发表于 2004-11-01 13:48 |只看该作者

如何实现一个单链表的反转?

>;>;return (L + len);
这是对数组的用法。你能保证这些结点在物理地址上是连续分布的吗?

论坛徽章:
0
23 [报告]
发表于 2004-11-01 13:51 |只看该作者

如何实现一个单链表的反转?

个人认为,如果真的如楼主所说的不能用其他的指针去存储结点变量是不能完成链表的逆转的,因为最少你都需要一个指针作为游标来遍历这个链表呀。

论坛徽章:
0
24 [报告]
发表于 2004-11-01 14:07 |只看该作者

如何实现一个单链表的反转?

我觉得真正要实现楼竹所说,是不可能得

论坛徽章:
0
25 [报告]
发表于 2004-11-01 14:07 |只看该作者

如何实现一个单链表的反转?

论坛徽章:
0
26 [报告]
发表于 2004-11-01 14:14 |只看该作者

如何实现一个单链表的反转?

原帖由 "converse" 发表:
>;>;return (L + len);
这是对数组的用法。你能保证这些结点在物理地址上是连续分布的吗?


说的是,没考虑到这点
不过思路还是一样的
修改一下

  1. typedef   struct Node{
  2.    ElementType element;
  3.    Node *next;
  4. }Node;


  5. Node *ReverseList(Node *List){
  6.    Node *L, *tmp, *p;
  7.    int len, i , j;
  8.    
  9.    len = ListLen(List);//求出单向练表的长度
  10.     L = List;
  11.     tmp = L;

  12. // 节点N指向节点N-1
  13.     for( i = len; i >; 0; i-- ){
  14.                          for(j = i -1 ;  j >; 0;  j-- ){//找i-1节点指针
  15.                                                tmp = tmp->;next;
  16.                                     }
  17.                           if(i == len){//保存表尾指针
  18.                                           p = tmp->;next;
  19.                             }
  20.                            tmp->;next = tmp;  // 节点N指向节点N-1
  21.                            tmp = L;
  22.     }

  23.     L->;next = NULL;

  24.    return p;
  25. }
复制代码
zkyguanl 该用户已被删除
27 [报告]
发表于 2004-11-01 14:46 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
28 [报告]
发表于 2004-11-01 15:48 |只看该作者

如何实现一个单链表的反转?

[quote]原帖由 "converse"]头尾交换,不断地往中间靠是吧?[/quote 发表:

不是。
我现在忙,没时间编码。

论坛徽章:
0
29 [报告]
发表于 2004-11-01 16:26 |只看该作者

如何实现一个单链表的反转?

原帖由 "flw" 发表:

不要动不动就骂老师。
是你没有理解清楚人家的意思。
这个题目没有任何问题,
而且 converse 已经给出了一种方法。


我不认为我没理解清楚楼主的意思.
如果楼主的意思真的是你所说的那种意思,
那楼主的表达方式也太成问题了.

论坛徽章:
0
30 [报告]
发表于 2004-11-01 16:40 |只看该作者

如何实现一个单链表的反转?

[quote]原帖由 "FreeGnu"][/quote 发表:

我觉得写成这个函数,在实际运行中,可能会出现断链的问题
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP