链表排序之快排与归并(递归与非递归)

链表排序之快排与归并(递归与非递归)




1.对链表进行快速排序

以【4,2,5,3,7,9,0,1】为例,我们来模拟一趟快排的过程。

**1、**初始化时,i指向链表首元素4;j = i +1,指向2。基准数字为当前i 指向的数字:4。

j
4 2 5 3 7 9 0 1
i

**2、**随后开始循环,j 当前指向2,因为2小于4,所以要把2移动到前面去。按照我们的算法步骤操作:

  • i ++,首先 i 向后移动一位,指向2
  • swap(i, j) ,随后交换 i、j 位置的值,这里面是2和2自己交换
  • j ++,然后 j 向后移动一位,指向5

执行一次交换后的结果如下:

j
4 2 5 3 7 9 0 1
i

**3、**接下来,由于 j 指向的值5 大于4,直接跳过,执行j++,此时 j 指向3

j
4 2 5 3 7 9 0 1
i

4、 j 指向的值为3,小于4,仿照步骤2,我们再次执行一次交换移动过程。

  • i ++,首先 i 向后移动一位,指向5
  • swap(i, j) ,随后交换 i、j 位置的值,这里面是5和3交换
  • j ++,然后 j 向后移动一位,指向7

交换后的结果如下:

j
4 2 3 5 7 9 0 1
i

5、 j指向的值为7,大于4,所以直接跳过,执行 j++,j 指向9

j
4 2 3 5 7 9 0 1
i

**6、**同理,j 指向的值为9,也大于4,跳过,执行 j++,j 指向0

j
4 2 3 5 7 9 0 1
i

7、 j 指向的值为0,小于4,执行一次交换过程

  • i ++,首先 i 向后移动一位,指向5
  • swap(i, j) ,随后交换 i、j 位置的值,这里面是5和0交换
  • j ++,然后 j 向后移动一位,指向1

交换后的结果如下:

j
4 2 3 0 7 9 5 1
i

8、 j 指向的值为1,小于4,我们再执行一次交换过程

  • i ++,首先 i 向后移动一位,指向7
  • swap(i, j) ,随后交换 i、j 位置的值,这里面是7和1交换
  • j ++,然后 j 向后移动一位,已经超过了链表的长度,不再向后移动。

交换后的结果如下:

j
4 2 3 0 1 9 5 7
i

**9、**最后,交换当前 i指向的值1,和4。得到【1、2、3、0、4、9、5、7】,一趟排序结束。

j
1 2 3 0 4 9 5 7
i

我们发现,4的左边都是小于4的数字,右边都是大于4的数字。
接下来,对左边和右边分别排序,不断递归下去,直到元素全部有序。


代码如下:

非递归-用栈:

package com.m.test;

import java.util.Stack;
import java.util.LinkedList;
import java.util.List;

public class Test {
   

	public static void fun1(List<Integer> arr, int left, int right) {
   
		Stack<Integer> stack = new Stack<Integer>();
		if (left < right) {
   
			stack.add(left);
			stack.add(right);
			while (!stack.isEmpty()) {
   
				int ri = stack.pop();
				int le = stack.pop();
				int k = quickSort1(arr, le, ri);
				if (le < k - 1) {
   
					stack.push(le);
					stack.push(k - 1);
				}
				if (ri > k + 1) {
   
					stack.push(k + 1);
					stack.push(ri);
				}

			}
		}
	}

	public static int quickSort1(List<Integer> list, int left, int right) {
   
		dealPivot1(list, left, right);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值