快速排序案例演示

def quick_sort(arr, low, high):
    """
    快速排序
    :param arr: 待排序数组
    :param low: 数组起始索引
    :param high: 数据结束索引
    :return: 排好序数组
    """
    if low >= high:
        return arr
    mid_value = arr[low]

    while low < high:
        # 如果 low<high 并且 大游标的值 大于等于 中间值,那么符合要求。-1 游标往下走
        # 如果 大游标的值 小于 中间值时,while不成立,此时大游标对应的值 附给 小游标的值
        while low < high and arr[high] >= mid_value:
            high -= 1
        arr[low] = arr[high]

        while low < high and arr[high] <= mid_value:
            low += 1
        arr[high] = arr[low]

    # 循环退出时, low=high
    arr[low] = mid_value

    return arr
    
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
根据提供的引用内容,我们可以看到其中包含了Java数组排序和数组猜数字游戏案例的内容。因此,我们可以结合这两个内容来回答这个问题。 Java中的快速排序是一种常用的排序算法,其基本思想是通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,然后再分别对这两部分记录继续进行排序,以达到整个序列有序的目的。 下面是一个使用Java实现快速排序的例子: ```java public class QuickSort { public static void quickSort(int[] arr, int left, int right) { if (left < right) { int i = left, j = right, x = arr[left]; while (i < j) { while (i < j && arr[j] >= x) { j--; } if (i < j) { arr[i++] = arr[j]; } while (i < j && arr[i] < x) { i++; } if (i < j) { arr[j--] = arr[i]; } } arr[i] = x; quickSort(arr, left, i - 1); quickSort(arr, i + 1, right); } } public static void main(String[] args) { int[] arr = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5}; quickSort(arr, 0, arr.length - 1); System.out.println(Arrays.toString(arr)); } } ``` 上述代码中,我们定义了一个`quickSort`方法,该方法接收一个整型数组`arr`、一个整数`left`和一个整数`right`作为参数,其中`left`和`right`分别表示待排序数组的左右边界。在方法中,我们首先判断`left`是否小于`right`,如果是,则进行快速排序。具体实现过程如下: 1. 定义三个整型变量`i`、`j`和`x`,其中`i`和`j`分别表示待排序数组的左右指针,`x`表示待排序数组的第一个元素。 2. 在循环中,我们首先从右向左遍历数组,找到第一个小于`x`的元素,将其赋值给`arr[i]`,然后将`i`加1。接着从左向右遍历数组,找到第一个大于等于`x`的元素,将其赋值给`arr[j]`,然后将`j`减1。 3. 如果`i`小于`j`,则将`arr[j]`赋值给`arr[i]`,然后将`i`加1,`j`减1。 4. 当`i`等于`j`时,将`x`赋值给`arr[i]`。 5. 最后,递归调用`quickSort`方法,对左右两个子数组进行排序。 接下来,我们可以结合数组猜数字游戏案例演示如何使用快速排序。在这个案例中,我们需要生成一个长度为10的随机整数数组,并让用户猜测其中的一个数字。每次猜测后,程序会告诉用户猜测的数字是大于还是小于目标数字,直到用户猜中为止。 下面是一个使用Java实现的数组猜数字游戏案例: ```java import java.util.Arrays; import java.util.Random; import java.util.Scanner; public class GuessNumber { public static void main(String[] args) { int[] arr = new int[10]; Random random = new Random(); for (int i = 0; i < arr.length; i++) { arr[i] = random.nextInt(100); } quickSort(arr, 0, arr.length - 1); System.out.println(Arrays.toString(arr)); Scanner scanner = new Scanner(System.in); int target = arr[random.nextInt(10)]; System.out.println("猜一个0到99之间的数字:"); while (true) { int guess = scanner.nextInt(); if (guess == target) { System.out.println("恭喜你猜对了!"); break; } else if (guess < target) { System.out.println("猜小了,请继续猜:"); } else { System.out.println("猜大了,请继续猜:"); } } } public static void quickSort(int[] arr, int left, int right) { if (left < right) { int i = left, j = right, x = arr[left]; while (i < j) { while (i < j && arr[j] >= x) { j--; } if (i < j) { arr[i++] = arr[j]; } while (i < j && arr[i] < x) { i++; } if (i < j) { arr[j--] = arr[i]; } } arr[i] = x; quickSort(arr, left, i - 1); quickSort(arr, i + 1, right); } } } ``` 上述代码中,我们首先生成一个长度为10的随机整数数组,并使用快速排序对其进行排序。然后,我们随机选择一个数组元素作为目标数字,并让用户猜测该数字。在循环中,我们不断读取用户输入的数字,并与目标数字进行比较,直到用户猜中为止。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cts618

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值