重排链表

将给定的单链表L: L_0→L_1→…→L_{n-1}→L_n
重新排序为:L_0→L_n →L_1→L_{n-1}→L_2→L_{n-2}→…...
要求使用原地算法,不能改变节点内部的值,需要对实际的节点进行交换。
例如:
对于给定的单链表{10,20,30,40},将其重新排序为{10,40,20,30}.

/*
 * function ListNode(x){
 *   this.val = x;
 *   this.next = null;
 * }
 */

/**
 * 
 * @param head ListNode类 
 * @return void
 */
function reorderList( head ) {
    // write code here
    if(head==null||head.next==null||head.next.next==null){return head}
    var arr = []
    var current = head
    while(current){
        arr.push(current)
        current = current.next
    }
    var i = 0
    var j = arr.length-1
    while(i<j){
        if(i+1 == j){
            break;
        }
        arr[i].next = arr[j]
        arr[j-1].next = null
        arr[j].next = arr[i+1]
        i++
        j--
    }
    return arr[0]
}
module.exports = {
    reorderList : reorderList
};
链表算法 文章被收录于专栏

链表相关算法

全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 12:11
我最近都有点不想活了,天天早10晚11的,还问我爱不爱她目前的状态别说爱谁了,没扇谁就不错了。是不是大家都是一进节子,只有工作没有爱情了
AzureSkies:在字节的时候找的就是字节的,飞书太适合恋爱人士了,能看到是不是已读,是不是在会议中。简直冥婚好伴侣
投递字节跳动等公司9个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务