题解 | #牛群的身高排序#

牛群的身高排序

https://www.nowcoder.com/practice/9ce3d60e478744c09768d1aa256bfdb5

题目考察的知识点

从题目考察的知识点来看,这是一道关于链表的题目,要求将链表中的身高数据按升序排列并返回排序后的链表。解题的核心思路是使用归并排序对链表进行排序。

题目解答方法的文字分析

在代码的实现上,首先需要定义一个函数merge,用于合并两个有序链表。然后,通过快慢指针找到链表的中点,将链表拆分为两部分,并递归地对这两部分链表进行排序和合并操作。最后,通过调用归并排序的函数对整个链表进行排序。

本题解析所用的编程语言

本题解析使用了JavaScript作为编程语言进行示例代码的展示。JavaScript是一种流行的脚本语言,广泛应用于前端开发和服务器端开发。

完整且正确的编程代码

function sortList(head) {
    if (!head || !head.next) {
        return head; // 链表为空或只有一个节点,无需排序,直接返回原链表
    }
  
    // 定义合并两个有序链表的函数
    const merge = (l1, l2) => {
        const dummy = new ListNode(0); // 创建一个虚拟头节点
        let curr = dummy;
      
        while (l1 && l2) {
            if (l1.val <= l2.val) {
                curr.next = l1;
                l1 = l1.next;
            } else {
                curr.next = l2;
                l2 = l2.next;
            }
            curr = curr.next;
        }
      
        curr.next = l1 ? l1 : l2; // 将剩余的节点接到合并后的链表中
      
        return dummy.next;
    };
  
    // 快慢指针找到链表的中点
    const findMid = (head) => {
        let slow = head;
        let fast = head;
        let prev = null;
      
        while (fast && fast.next) {
            prev = slow;
            slow = slow.next;
            fast = fast.next.next;
        }
      
        prev.next = null; // 断开链表
      
        return slow;
    };
  
    // 递归地对链表进行拆分和合并
    const mergeSort = (head) => {
        if (!head || !head.next) {
            return head; // 链表为空或只有一个节点时,无需继续拆分和合并
        }
      
        const mid = findMid(head);
        const left = mergeSort(head);
        const right = mergeSort(mid);
      
        return merge(left, right); // 合并左右两部分链表
    };
  
    return mergeSort(head);
}
#面试高频TOP202#
题解 | 前端刷题 文章被收录于专栏

题目考察的知识点 题目解答方法的文字分析 本题解析所用的编程语言 完整且正确的编程代码

全部评论

相关推荐

头像
不愿透露姓名的神秘牛友
05-27 11:41
已编辑
点赞 评论 收藏
转发
点赞 收藏 评论
分享
牛客网
牛客企业服务