当前位置: 首页 > news >正文

免费网站开发如何推广网站运营

免费网站开发,如何推广网站运营,中国招标网官网首页,重庆杂酱面的制作题目 输入k个排序的链表,请将它们合并成一个排序的链表。 分析:利用最小堆选取值最小的节点 用k个指针分别指向这k个链表的头节点,每次从这k个节点中选取值最小的节点。然后将指向值最小的节点的指针向后移动一步,再比较k个指…

题目

输入k个排序的链表,请将它们合并成一个排序的链表。
在这里插入图片描述

分析:利用最小堆选取值最小的节点

用k个指针分别指向这k个链表的头节点,每次从这k个节点中选取值最小的节点。然后将指向值最小的节点的指针向后移动一步,再比较k个指针指向的节点并选取值最小的节点。重复这个过程,直到所有节点都被选取出来。

public class Test {public static void main(String[] args) {ListNode listNode1 = new ListNode(1);ListNode listNode2 = new ListNode(2);ListNode listNode3 = new ListNode(3);ListNode listNode4 = new ListNode(4);ListNode listNode5 = new ListNode(5);ListNode listNode6 = new ListNode(6);ListNode listNode7 = new ListNode(7);ListNode listNode8 = new ListNode(8);ListNode listNode9 = new ListNode(9);listNode1.next = listNode4;listNode4.next = listNode7;listNode2.next = listNode5;listNode5.next = listNode8;listNode3.next = listNode6;listNode6.next = listNode9;ListNode[] lists = {listNode1, listNode2, listNode3};ListNode result = mergeKLists(lists);while (result != null) {System.out.println(result.val);result = result.next;}}public static ListNode mergeKLists(ListNode[] lists) {ListNode dummy = new ListNode(0);ListNode cur = dummy;PriorityQueue<ListNode> minHeap = new PriorityQueue<>((n1, n2) -> n1.val - n2.val);for (ListNode list : lists) {if (list != null) {minHeap.offer(list);}}while (!minHeap.isEmpty()) {ListNode least = minHeap.poll();cur.next = least;cur = least;if (least.next != null) {minHeap.offer(least.next);}}return dummy.next;}
}

分析:按照归并排序的思路合并链表

输入的k个排序链表可以分成两部分,前k/2个链表和后k/2个链表。如果将前k/2个链表和后k/2个链表分别合并成两个排序的链表,再将两个排序的链表合并,那么所有链表都合并了。合并k/2个链表与合并k个链表是同一个问题,可以调用递归函数解决。

public class Test {public static void main(String[] args) {ListNode listNode1 = new ListNode(1);ListNode listNode2 = new ListNode(2);ListNode listNode3 = new ListNode(3);ListNode listNode4 = new ListNode(4);ListNode listNode5 = new ListNode(5);ListNode listNode6 = new ListNode(6);ListNode listNode7 = new ListNode(7);ListNode listNode8 = new ListNode(8);ListNode listNode9 = new ListNode(9);listNode1.next = listNode4;listNode4.next = listNode7;listNode2.next = listNode5;listNode5.next = listNode8;listNode3.next = listNode6;listNode6.next = listNode9;ListNode[] lists = {listNode1, listNode2, listNode3};ListNode result = mergeKLists(lists);while (result != null) {System.out.println(result.val);result = result.next;}}public static ListNode mergeKLists(ListNode[] lists) {if (lists.length == 0) {return null;}return mergeLists(lists, 0, lists.length);}private static ListNode mergeLists(ListNode[] lists, int start, int end) {if (start + 1 == end) {return lists[start];}int mid = (start + end) / 2;ListNode head1 = mergeLists(lists, start, mid);ListNode head2 = mergeLists(lists, mid, end);return merge(head1, head2);}private static ListNode merge(ListNode head1, ListNode head2) {ListNode dummy = new ListNode(0);ListNode cur = dummy;while (head1 != null && head2 != null) {if (head1.val < head2.val) {cur.next = head1;head1 = head1.next;}else {cur.next = head2;head2 = head2.next;}cur = cur.next;}cur.next = head1 == null ? head2 : head1;return dummy.next;}
}
http://www.ds6.com.cn/news/26998.html

相关文章:

  • 同城装修网网站内容seo
  • 承德 网站建设可以推广的平台
  • 广东阳江发布最新消息超级优化空间
  • flask网站开发怎么创建自己的游戏网站
  • 怎么做信息发布型网站网站建设知名公司
  • 嵌入式软件开发怎么学厦门seo顾问
  • 国外 网站 设计最新的疫情数据
  • 石家庄网站设计制作服务排名seo怎么样
  • zenme用ps做网站图seo关键词推广价格
  • 海南网站策划深圳企业seo
  • 国内做新闻比较好的网站b2b网站免费推广
  • 企业门户网站设计搜索引擎有哪些网站
  • 建设部网站不支持360网页推广怎么做
  • 做网站ie10缓存西安网站制作工作室
  • 推广图片模版友链对网站seo有帮助吗
  • 做视频素材怎么下载网站成人技能培训机构
  • 那个网站做足球测互联网行业都有哪些工作
  • 免费咨询医生有问必答seo的基础优化
  • 在线做图表的网站建立网站的软件
  • 做装修效果图的网站有哪些免费seo软件
  • 公司做网站需要服务器吗黄冈网站推广软件视频下载
  • seo做的不好的网站百度权重网站排名
  • 网页设计与网站建设书籍怎样在百度上推广
  • 深圳市做网站的360网站推广客服电话
  • php毕业设计代做网站快速排名程序
  • 注册官网百度关键词seo排名优化
  • 自适应网站做1920的网站推广渠道
  • 网站建设刂搜金手指下拉贰肆陕西网站制作
  • wordpress 回复 楼中楼成都正规搜索引擎优化
  • 精品网站建设公司外链官网