[剑指offer][JAVA]面试题[第23题][合并K个排序链表][分治][优先队列]

【问题描述】23.合并K个排序链表

合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。
示例:
输入:
[1->4->5,1->3->4,2->6
]
输出: 1->1->2->3->4->4->5->6

【解答思路】

1. 两两合并
public class Solution2 {public ListNode mergeKLists(ListNode[] lists) {int size = lists.length;if (size == 0) {return null;}ListNode res = lists[0];for (int i = 1; i < size; i++) {if (lists[i] != null) {res = mergeTwoSortLinkedList(res, lists[i]);}}return res;}private ListNode mergeTwoSortLinkedList(ListNode list1, ListNode list2) {ListNode dummyNode = new ListNode(-1);ListNode p1 = list1;ListNode p2 = list2;ListNode curNode = dummyNode;// 两者都不为空的时候,才有必要进行比较while (p1 != null && p2 != null) {if (p1.val < p2.val) {// 指针修改发生在这里curNode.next = p1;p1 = p1.next;} else {// 指针修改发生在这里curNode.next = p2;p2 = p2.next;}curNode = curNode.next;}// 跳出循环是因为 p1 == null 或者 p2 == nullif (p1 == null) {curNode.next = p2;}if (p2 == null) {curNode.next = p1;}return dummyNode.next;}
}作者:liweiwei1419
链接:https://leetcode-cn.com/problems/merge-k-sorted-lists/solution/tan-xin-suan-fa-you-xian-dui-lie-fen-zhi-fa-python/
2. 分治法

想清楚数据结构 ListNode[] 只存了头节点
1、先一分为二,分别“递归地”解决了与原问题同结构,但规模更小的两个子问题;
2、再考虑如何合并,这个合并的过程也是一个递归方法(同 LeetCode 第 21 题:合并两个有序链表)。
时间复杂度:O(NlogN)

import java.util.Comparator;
import java.util.PriorityQueue;class ListNode {int val;ListNode next;ListNode(int x) {val = x;}
//测试使用ListNode(Integer[] nums) {ListNode currNode = this;currNode.val = nums[0];for (int i = 1; i < nums.length; i++) {currNode.next = new ListNode(nums[i]);currNode = currNode.next;}}
//测试使用@Overridepublic String toString() {ListNode currNode = this;StringBuilder s = new StringBuilder();while (currNode != null) {s.append(currNode.val);s.append(" -> ");currNode = currNode.next;}// 最后添加一个 NULL 标志表示添加到末尾了s.append("NULL");return s.toString();}
}public class Solution {public ListNode mergeKLists(ListNode[] lists) {int len = lists.length;if (len == 0) {return null;}return mergeKLists(lists, 0, len - 1);}public ListNode mergeKLists(ListNode[] lists, int l, int r) {// 思考这里为什么取等于?这是因为根据下文对 mergeKLists 的递归调用情况,区间最窄的时候,只可能是左右端点重合if (l == r) {return lists[l];}int mid = (r - l) / 2 + l;ListNode l1 = mergeKLists(lists, l, mid);ListNode l2 = mergeKLists(lists, mid + 1, r);return mergeTwoSortedListNode(l1, l2);}private ListNode mergeTwoSortedListNode(ListNode l1, ListNode l2) {if (l1 == null) {return l2;}if (l2 == null) {return l1;}if (l1.val < l2.val) {l1.next = mergeTwoSortedListNode(l1.next, l2);return l1;}l2.next = mergeTwoSortedListNode(l1, l2.next);return l2;}
}作者:liweiwei1419
链接:https://leetcode-cn.com/problems/merge-k-sorted-lists/solution/tan-xin-suan-fa-you-xian-dui-lie-fen-zhi-fa-python/
3. 贪心算法、优先队列 (最小堆)


时间复杂度:O(NlogN) 空间复杂度:O(N)

import java.util.Comparator;
import java.util.PriorityQueue;class ListNode {int val;ListNode next;ListNode(int x) {val = x;}
//n条链表合成一条 测试使用ListNode(Integer[] nums) {ListNode currNode = this;currNode.val = nums[0];for (int i = 1; i < nums.length; i++) {currNode.next = new ListNode(nums[i]);currNode = currNode.next;}}
//测试使用 @Overridepublic String toString() {ListNode currNode = this;StringBuilder s = new StringBuilder();while (currNode != null) {s.append(currNode.val);s.append(" -> ");currNode = currNode.next;}// 最后添加一个 NULL 标志表示添加到末尾了s.append("NULL");return s.toString();}
}public class Solution {public ListNode mergeKLists(ListNode[] lists) {int len = lists.length;if (len == 0) {return null;}PriorityQueue<ListNode> priorityQueue = new PriorityQueue<>(len, Comparator.comparingInt(a -> a.val));/*@Overridepublic int compare(ListNode o1, ListNode o2) {if (o1.val < o2.val) return -1;else if (o1.val == o2.val) return 0;else return 1;}*/ListNode dummyNode = new ListNode(-1);ListNode curNode = dummyNode;for (ListNode list : lists) {if (list != null) {// 这一步很关键,不能也没有必要将空对象添加到优先队列中priorityQueue.add(list);}}while (!priorityQueue.isEmpty()) {// 优先队列非空才能出队ListNode node = priorityQueue.poll();// 当前节点的 next 指针指向出队元素curNode.next = node;// 当前指针向前移动一个元素,指向了刚刚出队的那个元素curNode = curNode.next;if (curNode.next != null) {// 只有非空节点才能加入到优先队列中priorityQueue.add(curNode.next);}}return dummyNode.next;}public static void main(String[] args) {Integer[] nums1 = {1, 4, 5};Integer[] nums2 = {1, 3, 4};Integer[] nums3 = {2, 6};ListNode head1 = new ListNode(nums1);ListNode head2 = new ListNode(nums2);ListNode head3 = new ListNode(nums3);ListNode[] lists = new ListNode[3];lists[0] = head1;lists[1] = head2;lists[2] = head3;Solution solution = new Solution();ListNode mergeKLists = solution.mergeKLists(lists);System.out.println(mergeKLists);}
}作者:liweiwei1419
链接:https://leetcode-cn.com/problems/merge-k-sorted-lists/solution/tan-xin-suan-fa-you-xian-dui-lie-fen-zhi-fa-python/

【总结】

1.递归思想

1、数组的排序方法要很清楚,这一点是迁移到链表上,发现只有归并排序适用;
2、归并排序其实就是分而治之;
3、还要清楚两个排序链表是怎么合并的(可以递归也可以非递归用双指针去穿针引线)。
如果这些所以就很自然迁移到合并 K 个排序链表。

2.链表
  • “递归”、“分治”
  • “穿针引线” 优先队列 堆
3.PriorityQueue

1>PriorityQueue是一种无界的,线程不安全的队列(无锁)
2>PriorityQueue是一种通过数组实现的,并拥有优先级的队列
3>PriorityQueue存储的元素要求必须是可比较的对象Comparator(数量+比较对象), 如果不是就必须明确指定比较器

优先队列java解析与用法:https://www.jb51.net/article/84371.htm
优先队列源码解析:https://www.cnblogs.com/CarpenterLee/p/5488070.html
解题解析:https://leetcode-cn.com/problems/merge-k-sorted-lists/solution/tan-xin-suan-fa-you-xian-dui-lie-fen-zhi-fa-python/

异度侵入

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/425994.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[Leedcode][JAVA][第542题][01矩阵][BFS]

【问题描述】542. 01 矩阵 给定一个由 0 和 1 组成的矩阵&#xff0c;找出每个元素到最近的 0 的距离。 两个相邻元素间的距离为 1 。 示例 : 输入: 0 0 0 0 1 0 1 1 1 输出: 0 0 0 0 1 0 1 2 1 注意: 给定矩阵的元素个数不超过 10000。 给定矩阵中至少有一个元素是 0。 矩阵…

java学习(159):两个线程共同完成1到100计算

//利用两个线程实现1到100的计算 public class MyRannable implements java.lang.Runnable{private Thread th_0;private Thread th_2;int sum0;//存储累加和的结果int i1;public void run(){String thNameThread.currentThread().getName();//获取当前线程的名字while (i<…

java学习(160):interrupt方法

import java.util.PrimitiveIterator;public class Classroon implements Runnable {private Thread student;//学生线程private Thread teacher;//老师线程public Classroon(){student new Thread( this,"小迷糊" );teacher new Thread( this,"大教授" …

elementui图片上传php,vue+element-ui+富文本————图片上传

最近用vueelement-ui开发一套后台管理系统&#xff0c;其中项目中需要用到富文本编辑器&#xff0c;这里总结下开发过程中遇到的坑和使用方法。刚开始用的是vue-quill-editor结合element-ui上传图片到服务器&#xff0c;name问题来了 按照官方文档上面的方式。下面是我的代码cl…

[剑指offer][JAVA][面试第40题][最小的k个数][快选][堆][BST]

【问题描述】面试第40题 最小的k个数 输入整数数组 arr &#xff0c;找出其中最小的 k 个数。例如&#xff0c;输入4、5、1、6、2、7、3、8这8个数字&#xff0c;则最小的4个数字是1、2、3、4。 示例 &#xff1a; 输入&#xff1a;arr [3,2,1], k 2 输出&#xff1a;[1,2] …

java学习(161):同步代码块

public class SynCode implements Runnable{public void run(){synchronized (this){Thread currentThread.currentThread();//获取当前线程for(int i1;i<10;i){System.out.println( "当前执行代码块的名称为" current.getName());try {Thread.sleep( 1000 );}cat…

[如何做研究][如何写论文]

音频 沈向洋&#xff1a;有效的科研法则 科学上网&#xff1a;https://www.youtube.com/watch?vU6r3R87AKHI&featureyoutu.be 视频 文章 【经典重温】MIT人工智能实验室: 如何做研究&#xff1f; 机器学习研究者的养成指南&#xff0c;吴恩达建议这么读论文 周志华 […

java学习(162):同步对象锁

定义一个dog类 public class Dog {private String name;public String getName() {return name;}public void setName(String name) {this.name name;} }定义一个同步对象锁 //同步对象锁 public class SysObject implements Runnable {private Dog dog;public SysObject(){…

[Leedcode][JAVA][第56题][合并区间][数组][贪心算法]

【问题描述】56.合并区间 给出一个区间的集合&#xff0c;请合并所有重叠的区间。 示例 1: 输入: [[1,3],[2,6],[8,10],[15,18]] 输出: [[1,6],[8,10],[15,18]] 解释: 区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].【解答思路】 1. 双指针 左边位置一定是确定&#xff0c;…

java读写注册表的两种方式,Preferences与jRegistry

打开注册表方式&#xff1a;电脑上的windows键加r键打开运行程序->输入指令regedit->随即系统便会提示你是否要运行&#xff0c;选择“是“就行了 由于java程序是“write once, run everywhere”&#xff0c;用java读写注册表&#xff0c;那程序的跨平台性就差了。java对…

java学习(163):同步方法锁

public class SynMethon implements Runnable{private double money1000000;public void run(){dbMoney();}//同步方法private synchronized void dbMoney(){Thread tThread.currentThread();for(int i1;i<10;i){if(t.getName().equals( "会计" )){moneyi*10;Sy…

PBFT

摘要&#xff1a; PBFT是Practical Byzantine Fault Tolerance的缩写&#xff0c;即&#xff1a;实用拜占庭容错算法。该算法是Miguel Castro&#xff08;卡斯特罗&#xff09;和Barbara Liskov&#xff08;利斯科夫&#xff09;在1999年提出来的&#xff0c;解决了原始拜占庭…

Python爬虫爬取美剧网站

一直有爱看美剧的习惯&#xff0c;一方面锻炼一下英语听力&#xff0c;一方面打发一下时间。之前是能在视频网站上面在线看的&#xff0c;可是自从广电总局的限制令之后&#xff0c;进口的美剧英剧等貌似就不在像以前一样同步更新了。 但是&#xff0c;作为一个宅diao的我又怎甘…

php 存储html 内容,HTML 本地存储

HTML 本地存储HTML 本地存储&#xff1a;优于 cookies。什么是 HTML 本地存储&#xff1f; ( 推荐学习&#xff1a;html教程 )通过本地存储(Local Storage)&#xff0c;web 应用程序能够在用户浏览器中对数据进行本地的存储。在 HTML5 之前&#xff0c;应用程序数据只能存储在 …

java学习(165):inetaddress和inetsocketaddress

import java.net.InetAddress; import java.net.InetSocketAddress; import java.net.UnknownHostException;//inetaddress public class test112 {public static void main(String[] args){try {InetAddress add0 InetAddress.getLocalHost();//获取本机ip地址实例System.out…

java学习(166):socket服务端和客户端连接

socket服务端 import java.io.IOException; import java.net.ServerSocket; import java.net.Socket;//socket服务端 public class test114 {public static void main(String[] args){ServerSocket serverSocketnull;Socket clientnull;/*创建服务器套接字*/try {serverSocket…

[Leedcode][JAVA][第11题][盛最多水的容器][双指针][贪心]

【问题描述】11.盛最多水的容器 给你 n 个非负整数 a1&#xff0c;a2&#xff0c;...&#xff0c;an&#xff0c;每个数代表坐标中的一个点 (i, ai) 。在坐标内画 n 条垂直线&#xff0c;垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0)。找出其中的两条线&#xff0c;使得它们与…

SAP S/4HANA使用ABAP获得生产订单的状态

在S/4HANA里&#xff0c;我们如何根据一个销售订单的行项目&#xff0c;查看对应的生产订单状态&#xff1f; 双击行项目&#xff1a; 点击Schedule line&#xff1a; 这里就能看到生产订单的ID和状态了。 其中订单的状态存储在表vsaufk里&#xff0c;注意订单和状态可以是1对多…

http:(1):http简介

HTTP 简介 HTTP协议是Hyper Text Transfer Protocol&#xff08;超文本传输协议&#xff09;的缩写,是用于从万维网&#xff08;WWW:World Wide Web &#xff09;服务器传输超文本到本地浏览器的传送协议。。 HTTP是一个基于TCP/IP通信协议来传递数据&#xff08;HTML 文件, …

[Leedcode][JAVA][第466题][统计重复个数][数组]

【问题描述】466. 统计重复个数 由 n 个连接的字符串 s 组成字符串 S&#xff0c;记作 S [s,n]。例如&#xff0c;["abc",3]“abcabcabc”。如果我们可以从 s2 中删除某些字符使其变为 s1&#xff0c;则称字符串 s1 可以从字符串 s2 获得。例如&#xff0c;根据定义…