当前位置: 首页 > article >正文

C/C++ 快速排序

个人主页:仍有未知等待探索_C语言疑难,数据结构,小项目-CSDN博客

专题分栏:算法_仍有未知等待探索的博客-CSDN博客

快速排序的思想——分治

目录

一、引言

二、讲解

1、步骤

2、代码

1.以左边界作为基准

2.以右边界作为基准

3.以中心点作为基准 


一、引言

快速排序是对冒泡排序的一种改进。它的基本思想在于划分,首先选一个基准x,让x的左边都小于x,让x的右边都大于x。然后通过递归,一直将数组分成两个或一个元素。

二、讲解

1、步骤

1、将确定分界点。

2、调整范围——让基准x的左边都小于x,让x的右边都大于x。

3、递归分治。

注意:边界问题

如果arr数组为:【0,1】

基准点为左边界。

x=0,i=-1,j=2;

因为i先自增,arr[0]==0,退出循环.。

j先自减,arr[j]>0,继续进入循环,j--,arr[j]==0,退出循环。

如果:

quick(arr,l,i-1);

quick(arr,i,r);

这样分治的话:第一个递归进入后会立刻退出来,因为分治的区间没有元素。第二个递归进入后,要进行划分的区间仍然是【0,1】,将会死循环,栈溢出。

所以分边界点的话要用j进行区分。

2、代码

1.以左边界作为基准

#include<iostream>
using namespace std;
#include<cstdio>
const int N = 1e5 + 5;
int arr[N], n;
void quick_sort(int arr[], int l, int r) {
    if (l >= r) {
        return;
    }
    //基准x是arr数组的左边界
    int i = l - 1, j = r + 1, x = arr[l];
    while (i < j) {
        do {
            i++;
        } while (arr[i] < x);
        do {
            j--;
        } while (arr[j] > x);
        if (i < j) {
            int temp;
            temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
    }
    //这块要配合着基准x为arr的左边界,下边的j不能换成i
    //如果要换成i的话,基准x也要跟着变
    quick_sort(arr, l, j);
    quick_sort(arr, j + 1, r);
}
int main() {
    scanf("%d", &n);
    for (int i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
    }
    quick_sort(arr, 0, n - 1);
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    return 0;
}

2.以右边界作为基准

#include<iostream>
using namespace std;
#include<cstdio>
const int N = 1e5 + 5;
int arr[N], n;
void quick_sort(int arr[], int l, int r) {
    if (l >= r) {
        return;
    }
    int i = l - 1, j = r + 1, x = arr[r];
    while (i < j) {
        do {
            i++;
        } while (arr[i] < x);
        do {
            j--;
        } while (arr[j] > x);
        if (i < j) {
            int temp;
            temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
    }
    quick_sort(arr, l, i-1);
    quick_sort(arr, i, r);
}
int main() {
    scanf("%d", &n);
    for (int i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
    }
    quick_sort(arr, 0, n - 1);
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    return 0;
}

3.以中心点作为基准 

#include<iostream>
using namespace std;
#include<cstdio>
const int N = 1e5 + 5;
int arr[N], n;
void quick_sort(int arr[], int l, int r) {
    if (l >= r) {
        return;
    }
    int i = l - 1, j = r + 1, x = arr[(l+r)/2];
    while (i < j) {
        do {
            i++;
        } while (arr[i] < x);
        do {
            j--;
        } while (arr[j] > x);
        if (i < j) {
            int temp;
            temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
    }
    quick_sort(arr, l, j);
    quick_sort(arr, j+1, r);
}
int main() {
    scanf("%d", &n);
    for (int i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
    }
    quick_sort(arr, 0, n - 1);
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    return 0;
}


http://www.kler.cn/news/155932.html

相关文章:

  • Python 错误 TypeError: __str__ Returned Non-String but Printing Output
  • 【源码解析】聊聊线程池 实现原理与源码深度解析(一)
  • 从零构建属于自己的GPT系列3:模型训练2(训练函数解读、模型训练函数解读、代码逐行解读)
  • 算法复习,数据结构 ,算法特性,冒泡法动态演示,复杂度,辗转相除法*,寻找最大公因数
  • Win中Redis部署与配置
  • SCAU:判断点是否在圆上
  • QWebChannel 是 Qt 框架中用于在 Web 页面和 Qt 应用程序之间进行通信的类
  • 【doccano】文本标注工具——属性级情感分析标注自己的业务数据
  • 使用SLS日志服务采集Kong网关的日志
  • c语言编程题经典100例——(41~45例)
  • Android textView 显示: STRING_TOO_LARGE
  • 23.12.3日总结
  • 鸿蒙工具DevEco Studio调试Build task failed. Open the Run window to view details.
  • 讲一讲redis的使用
  • WordPress外贸站优化工具,WordPress外贸SEO优化方法
  • iOS Class Guard 成功了,但无法区分差异
  • ssm医药进出口交易系统源码和论文
  • 移除元素、合并两个有序数组(leetcode)
  • 人工智能(pytorch)搭建模型21-基于pytorch搭建卷积神经网络VoVNetV2模型,并利用简单数据进行快速训练
  • Stable Diffusion 系列教程 - 1 基础准备(针对新手)
  • 浅析SD-WAN技术如何加强企业网络安全
  • YOLOv8 区域计数 | 入侵检测 | 人员闯入
  • 编程中常见的技术难题有哪些?By AI
  • java八股文
  • 文件操作详解
  • 猜数字赢金币
  • Unity报错总结
  • flutter开发实战-当前界面无操作60s返回主页实现
  • 力扣572:另一棵树的子树
  • 29 kafka动态配置