147. Insertion Sort List

原创 2016年05月31日 16:18:08

Sort a linked list using insertion sort.

题意:对链表进行插入排序。

思路:每次对tail之后的结点操作,并适当更新tail(或head)。

class Solution {
public:
	ListNode* insertionSortList(ListNode* head) {
		if (head == NULL)
			return head;
		ListNode* tail = head;
		ListNode* q = tail->next;
		while (q){
			//extract
			tail->next = q->next;

			//search
			ListNode* tmp = head;
			if (tmp->val >= q->val){
				q->next = tmp;
				head = q;
			}
			else{
				while (tmp != tail && tmp->next->val < q->val){
					tmp = tmp->next;
				}
				q->next = tmp->next;
				tmp->next = q;
				if (tmp == tail)
					tail = q;
			}
			//go on
			q = tail->next;
		}
		return head;
	}
};

二刷:链表的操作,设置一个dummy会好一些。插入排序,不能从后向前走,因为链表是单向的,所以每次要从头往后找。因此设置一个dummy就会方便很多。

class Solution {
public:
	ListNode* insertionSortList(ListNode* head) {
		ListNode *dummy = new ListNode(0);
		ListNode *cur = head;
		while (cur){
			ListNode *tmp = cur->next;
			insert(dummy, cur);
			cur = tmp;
		}
		return dummy->next;
	}
private:
	void insert(ListNode *dummy, ListNode* cur){
		ListNode *pre = dummy;
		while (pre->next && pre->next->val < cur->val)
			pre = pre->next;
		ListNode *tmp = pre->next;
		pre->next = cur;
		cur->next = tmp;
	}
};





版权声明:本文为博主原创文章,未经博主允许不得转载。

【算法】插入排序 insertion_sort

准备写个《STL 源码剖析》的读书笔记,开个专栏,名为《STL 的实现》,将源码整理一遍。很喜欢侯捷先生写在封底的八个字:天下大事,必作于细!他在书中写到: 我开玩笑地对朋友说,这本书出版,给大学课程...
  • Justme0
  • Justme0
  • 2014年04月22日 17:20
  • 2481

Leetcode刷题记——147. Insertion Sort List(插入排序链表)

一、题目叙述: Sort a linked list using insertion sort. 二、解题思路: Medium题,啊。。。我今天头晕脑胀,写的不太...
  • sunshine0_0
  • sunshine0_0
  • 2017年02月27日 18:52
  • 209

插入排序(insert_sort)与 并归排序(merge_sort) 算法分析

(一)插入排序 算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。 插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序...
  • hustyangju
  • hustyangju
  • 2014年05月09日 13:53
  • 1253

Insertion Sort List(自我感觉写的挺好)

果然脑袋混沌的时候就应该去放松一下,昨天下午xiang
  • seagullyoyo
  • seagullyoyo
  • 2014年07月19日 09:46
  • 312

Insertion Sort(插入排序)

插入即表示将一个新的数据插入到一个有序数组中,并继续保持有序。例如有一个长度为N的无序数组,进行N-1次的插入即能完成排序;第一次,数组第1个数认为是有序的数组,将数组第二个元素插入仅有1个有序的数组...
  • H_earbeats
  • H_earbeats
  • 2017年08月07日 15:07
  • 109

java实现几种常见的排序算法

几种常见排序算法 几种常见排序算法 写在前面基础介绍初级排序算法 selection sort选择排序insertion sort插入排序ShellSort希尔排序s...
  • u011001084
  • u011001084
  • 2016年05月09日 21:17
  • 699

排序与list.sort()使用

排序与List.sort()
  • u011611902
  • u011611902
  • 2015年10月27日 16:46
  • 10525

LeetCode147_Insertion Sort List(用插入排序算法对链表进行排序) Java题解

题目: Sort a linked list using insertion sort. 题解: 插入排序就是先对一部分进行排序 排序好后将未排序的插入到已经排序好的队列中  在插入...
  • u012249528
  • u012249528
  • 2015年07月30日 16:38
  • 2260

C# List.sort排序详解(多权重,升序降序)

很多人可能喜欢Linq的orderBy排序,可惜U3D里面linq在Ios上会报错,所以就必须使用list的排序。 其实理解了并不难       升序降序比较 ...
  • holybomb
  • holybomb
  • 2016年11月01日 11:26
  • 5818

插入排序(insertion sort)(二)

基本思想:每趟将一个元素,按其关键字大小,插入到它前面已排序的子序列中,使得插入后的子序列仍是排序的,一次重复直到全部元素插入完毕。 插入排序算法有三种:直接插入排序、折半插入排序和希尔排序。 1.直...
  • DADADIE
  • DADADIE
  • 2015年03月29日 09:40
  • 756
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:147. Insertion Sort List
举报原因:
原因补充:

(最多只允许输入30个字)