免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 23970 | 回复: 3
打印 上一主题 下一主题

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

论坛徽章:
0
1 [报告]
发表于 2004-11-01 12:40 |显示全部楼层

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

修改节点指针不就OK了

论坛徽章:
0
2 [报告]
发表于 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
3 [报告]
发表于 2004-11-01 14:07 |显示全部楼层

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

论坛徽章:
0
4 [报告]
发表于 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. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP