太自由

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

题目:输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。

  • 代码如下
  1 public class Demo4 {
  2 
  3     public static void main(String[] args) {
  4         // 先创建多个节点,供测试使用
  5         ListNode listNode1 = new ListNode(1);
  6         ListNode listNode2 = new ListNode(2);
  7         ListNode listNode3 = new ListNode(6);
  8         ListNode listNode4 = new ListNode(14);
  9         ListNode listNode5 = new ListNode(15);
 10         // 把各个节点链起来
 11         listNode1.next = listNode2;
 12         listNode2.next = listNode3;
 13         listNode3.next = listNode4;
 14         listNode4.next = listNode5;
 15         listNode5.next = null;
 16         
 17         ListNode listNode6 = new ListNode(6);
 18         ListNode listNode7 = new ListNode(7);
 19         ListNode listNode8 = new ListNode(10);
 20         ListNode listNode9 = new ListNode(11);
 21         ListNode listNode10 = new ListNode(13);
 22         listNode6.next = listNode7;
 23         listNode7.next = listNode8;
 24         listNode8.next = listNode9;
 25         listNode9.next = listNode10;
 26         listNode10.next = null;
 27 
 28         System.out.println("原始链表1中的数据如下:");
 29         printList(listNode1);
 30         System.out.println("\n原始链表2中的数据如下:");
 31         printList(listNode6);
 32         
 33         System.out.println("\n\n合并之后的链表数据如下:");
 34         ListNode mergeHead = Merge(listNode1, listNode6);
 35         printList(mergeHead);
 36     }
 37     
 38     /**
 39      * 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。
 40      */
 41     public static ListNode Merge(ListNode list1,ListNode list2) {
 42         if(list1 == null) return list2;
 43         if(list2 == null) return list1;
 44         
 45         ListNode res = null;
 46         if(list1.val < list2.val){
 47             res = list1;
 48             res.next = Merge(list1.next, list2);
 49         }else{
 50             res = list2;
 51             res.next = Merge(list1, list2.next);
 52         }
 53         return res;
 54     }
 55     
 56     /**
 57      * 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。
 58      */
 59     public static ListNode myMerge(ListNode list1,ListNode list2) {
 60         if(list1 == null) return list2;
 61         if(list2 == null) return list1;
 62         ListNode mergeHead = null;
 63         ListNode current = null;
 64         while(list1 != null && list2 != null){
 65             if(list1.val <= list2.val){
 66                 if(mergeHead == null){
 67                     mergeHead = current = list1;
 68                 }else{
 69                     current.next = list1;
 70                     current = current.next;
 71                 }
 72                 list1 = list1.next;
 73             }else{
 74                 if(mergeHead == null){
 75                     mergeHead = current = list2;
 76                 }else{
 77                     current.next = list2;
 78                     current = current.next;
 79                 }
 80                 list2 = list2.next;
 81             }
 82         }
 83         if(list1 == null){
 84             current.next = list2;
 85         }else{
 86             current.next = list1;
 87         }
 88         return mergeHead;
 89     }
 90 
 91     /**
 92      * 遍历单链表
 93      * @param listNode
 94      */
 95     public static void printList(ListNode listNode) {
 96         ListNode tempNode = listNode;
 97         while(tempNode != null){
 98             System.out.printf("%d\t",tempNode.val);
 99             tempNode = tempNode.next;
100         }
101     }
102 }
1 public class ListNode {
2     int val;
3     ListNode next = null;
4 
5     public ListNode(int val) {
6         this.val = val;
7     }
8 }
  • 运行结果

 

posted on 2020-04-11 16:45  太自由  阅读(305)  评论(0编辑  收藏  举报