leetCode解题报告之Insertion Sort List


题目:

Sort a linked list using insertion sort.

分析:

这个题目是想要让我们来做一个链表的插入排序问题.

这样,我们只要从第一个元素一直往后,直到所有的节点都在前面的序列中找到自己所在的位置即可

情况:

1. 当前值比head的值还小,这情况要插入到head节点之前

2. 当前值比head的值大,这情况要插入到相应的位置

3. 当前值大于所有该节点之前的值,那么当cmpNode(用来作比较的结点)和自身相等的时候,只要将当前结点(nowNode)往后挪一个结点进行下一个结点的比较即可.


解题思路:

大家都知道,如果要在一个位置插入一个结点,那么要知道它的前一个位置的结点才可以,所以为了满足“情况1”,我们引入一个结点preHead(head的前一个结点),它的next域指向head。

接着引入一个 nowNode(当前结点) 和 一个 preNowNode(当前结点的前驱结点)【处于nowNode之前的那些结点是已经排好序了】

最后在引入一个cmpNode(做比较的结点) 和一个preCmpNode(正在做比较的结点的前驱结点) 【从head 直到 nowNode ,依次取出来 和 nowNode做比较,确定nowNode要插入的位置】


有了上面的这些介绍,剩下的看代码,应该就容易多了!!


附个过程图解:



 


package cn.xym.leetcode;




class ListNode {
	public int val;
	public ListNode next;


	ListNode(int x) {
		val = x;
		next = null;
	}
}


public class Solution {
	
	public static void main(String[] args) {
		ListNode head = new ListNode(10);
		ListNode head1 = new ListNode(3);
		ListNode head2 = new ListNode(8);
		ListNode head3 = new ListNode(22);
		ListNode head4 = new ListNode(15);
		ListNode head5 = new ListNode(50);
		
		head.next = head1;
		head1.next = head2;
		head2.next = head3;
		head3.next = head4;
		head4.next = head5;
		head5.next = null;
		
		head = insertionSortList(head);
		while (head != null){
			System.out.println(head.val);
			head = head.next;
		}
	}
	
	public static ListNode insertionSortList(ListNode head) {
		if (head == null || head.next == null) {
			return head;
		}
		
		ListNode preHead = new ListNode(Integer.MIN_VALUE);
		preHead.next = head;
		
		ListNode nowNode = head.next, preNowNode = head;
		while (nowNode != null){
			ListNode cmpNode = head;
			ListNode precmpNode = preHead;
			while (cmpNode != null && !cmpNode.equals(nowNode)){
				if (cmpNode.val > nowNode.val){
					if (cmpNode.equals(head)){
						preNowNode.next = nowNode.next;
						nowNode.next = preHead.next;
						preHead.next = nowNode;
						head = nowNode;
						nowNode = preNowNode.next;
					}else{
						preNowNode.next = nowNode.next;
						nowNode.next = precmpNode.next;
						precmpNode.next = nowNode;
						nowNode = preNowNode.next;
					}
					break;
				}else{
					precmpNode = cmpNode;
					cmpNode = cmpNode.next;
				}
			}
			if (cmpNode.equals(nowNode)){
				preNowNode = nowNode;
				nowNode = preNowNode.next;
			}
		}
		return preHead.next;
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值