《剑指offer》— JavaScript(15)反转链表

反转链表

题目描述

输入一个链表,反转链表后,输出链表的所有元素。


思路

(本题链表默认无头结点)

  1. pHead为当前结点,如果当前结点为空的话,直接返回;
  2. pHead为当前结点,pre为当前结点的前一个结点,next为当前结点的下一个结点;
  3. 需要完成的目标是将pre-->pHead-->next1-->next2-->··· ···-->end反转为pre<--pHead<--next1<--next2<--··· ···<--end;
  4. pre结点可以用来反转方向,为了避免反转之后链表断开,用next结点暂时保存next1结点;
  5. 先用next保存pHead的下一个结点信息,保证单链表不会断裂;
  6. 保存之后,让pHead从指向next变成指向pre;
  7. 到此,完成了pre到pHead的反转,即pre<--pHead;
  8. 将pre,pHead,next依次向后移动一个结点。
  9. 循环操作,直到pHead为null,此时pre就是链表的最后一个结点,链表反转完毕,pre为反转后链表的第一个结点。
  10. 输出pre就是反转之后所得的链表。

实现代码

// 判断对象是否为空
function isEmptyObject(obj) {
  for (var name in obj) {
  return false;
}
  return true;
} 

function ReverseList(pHead) {
    if (isEmptyObject(pHead)) {
        return false;
    }
    var pre = null;
    var next = null;
    while (pHead != null) {
        next = pHead.next;
        pHead.next = pre;
        pre = pHead;
        pHead = next;
    }
    return pre;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • //leetcode中还有花样链表题,这里几个例子,冰山一角 求单链表中结点的个数----时间复杂度O(n)这是最...
    暗黑破坏球嘿哈阅读 1,564评论 0 6
  • 转载请注明出处://www.greatytc.com/p/c65d9d753c31 在上一篇博客《数据结构...
    Alent阅读 3,546评论 4 74
  • 1. 逆序打印链表(单链表) 给定单链表,从尾到头打印每个节点的值,不同的值之间用空格隔开。比如:1>2>3>4>...
    少冰三hun甜阅读 4,068评论 1 12
  • 大学的时候不好好学习,老师在讲台上讲课,自己在以为老师看不到的座位看小说,现在用到了老师讲的知识,只能自己看书查资...
    和珏猫阅读 1,490评论 1 3
  • 链表是线性表的链式存储方式,逻辑上相邻的数据在计算机内的存储位置不一定相邻,那么怎么表示逻辑上的相邻关系呢? 可以...
    rainchxy阅读 2,079评论 0 6