首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C中的Quicksort实现?

Quicksort是一种常用的排序算法,它基于分治的思想,通过递归地将数组分成较小和较大的两个子数组来实现排序。下面是C语言中Quicksort的实现:

代码语言:c
复制
#include <stdio.h>

void swap(int* a, int* b) {
    int t = *a;
    *a = *b;
    *b = t;
}

int partition(int arr[], int low, int high) {
    int pivot = arr[high];
    int i = (low - 1);

    for (int j = low; j <= high - 1; j++) {
        if (arr[j] < pivot) {
            i++;
            swap(&arr[i], &arr[j]);
        }
    }
    swap(&arr[i + 1], &arr[high]);
    return (i + 1);
}

void quicksort(int arr[], int low, int high) {
    if (low < high) {
        int pi = partition(arr, low, high);

        quicksort(arr, low, pi - 1);
        quicksort(arr, pi + 1, high);
    }
}

void printArray(int arr[], int size) {
    for (int i = 0; i < size; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
}

int main() {
    int arr[] = {64, 34, 25, 12, 22, 11, 90};
    int n = sizeof(arr) / sizeof(arr[0]);
    printf("Original array: \n");
    printArray(arr, n);

    quicksort(arr, 0, n - 1);
    printf("Sorted array: \n");
    printArray(arr, n);

    return 0;
}

这段代码实现了Quicksort算法。首先定义了一个swap函数,用于交换两个元素的值。然后定义了partition函数,它选择数组中的最后一个元素作为基准值,将小于基准值的元素放在左侧,大于基准值的元素放在右侧,并返回基准值的索引。最后,定义了quicksort函数,它通过递归地对子数组进行排序。main函数中创建一个测试数组,并调用quicksort函数进行排序,最后输出排序后的结果。

Quicksort算法的优势在于其平均时间复杂度为O(nlogn),且具有原地排序的特性,不需要额外的存储空间。它在处理大规模数据时表现良好,并且易于实现。

Quicksort算法适用于各种排序场景,包括但不限于以下情况:

  • 对于大规模数据的排序,Quicksort的平均时间复杂度较低,性能较好。
  • 对于需要原地排序的场景,Quicksort不需要额外的存储空间。
  • 对于需要稳定排序的场景,Quicksort可以通过一些优化措施实现稳定排序。

腾讯云提供了多种云计算相关产品,其中与排序算法无直接关联。如果您对其他云计算领域的产品有兴趣,可以参考腾讯云官方文档或咨询腾讯云的客服人员。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

【优选算法】D&C-Quicksort-Mysteries:分治-快排的算法之迷

,但是此类算法对于带有重复性的排序很不友好,还是太慢了,因此对于这道题,也是一道经典的荷兰国旗问题,使用类似双指针算法中的移动零那道题的方法,划分区间比较排序,衍生出来了一种三划分排序算法,也叫作快速排序...k个最大元素 ✏️题目描述: ✏️示例: 传送门:数组中的第k个最大元素 题解: 本题要求找数组中的第k个最大元素,本质是快速排序算法中的快速选择算法,该方法同样适用第k小,前k大,前k小 细节问题...: 快速选择算法和快速排序基本上一样,唯一不同的是要在递归时选择区间,若c>=k,说明第k大落在大于基准元素的这段区间,那么只在这段区间寻找即可;若b+c>=k,说明第k大就在等于基准元素这段区间,即等于基准元素...;若前面两种都不成立,那么第k大一定落在比基准元素小的区间,因此在整个区间上找第k大相当于在左区间上找第k-b-c大 代码实现: #include #include 的数,只要求第k个数的位置,然后计算这个区间间的长度就行了 代码实现: #include #include #include using

7010
  • 快速排序quicksort_快速排序的原理

    大家好,又见面了,我是你们的朋友全栈君。 一、简介 快速排序是(Quick sort)是对冒泡排序的一种改进,是非常重要且应用比较广泛的一种高效率排序算法。...---- 二、算法思路 快速排序是通过多次比较和交换来实现排序,在一趟排序中把将要排序的数据分成两个独立的部分,对这两部分进行排序使得其中一部分所有数据比另一部分都要小,然后继续递归排序这两部分,最终实现所有数据有序...将大于或等于分界值的数据集中到右边,小于分界值的数据集中到左边。...一趟排序过后,左边部分中各个数据元素都小于分界值,而右边部分中各数据元素都大于或等于分界值,且右边部分个数据元素皆大于左边所有数据元素。...---- 五、代码实现 C void quick_sort(int *num,int l,int r){ //如果小于等于1个数据元素·直接返回结束快排函数 r为数组元素总个数 if(l+

    42350

    C# .NET 中的缓存实现

    C# .NET 中的缓存实现 软件开发中最常用的模式之一是缓存。这是一个简单但非常有效的概念,这个想法的核心是记录过程数据,重用操作结果。当执行繁重的操作时,我们会将结果保存在我们的缓存容器中。...早期做法 让我们用 C# 创建一个非常简单的缓存实现: public class NaiveCache { Dictionary _cache = new...但是,正如编程中的大多数事情一样,没有什么是那么简单的。由于多种原因,上述解决方案并不好。一方面,这个实现不是线程安全的。从多个线程使用时可能会发生异常。...这剥夺了我自己创建类似实现的乐趣,但至少我写这篇博文的工作量减少了。 我将向您展示微软的解决方案,如何有效地使用它,然后在某些场景中如何改进它。...关于GC压力的第一个问题:可以使用多种技术和启发式方法来监控GC压力。这篇博文与此无关,但您可以阅读我的文章在 C# .NET 中查找、修复和避免内存泄漏:8 个最佳实践[4]以了解一些有用的方法。

    3.9K40

    模拟实现c++中的vector模版

    三·vector模拟实现部分主要函数: 首先要知道这个模拟过程如图一样: 由于是类模版,一般定义和声明不能分文件,故可以都写在.h文件: 首先先不写构造,但是编译器默认生成的构造来,可能会给成员变量野指针...8·swap的实现: swap也为后面对于拷贝构造和赋值重载的现代版本使用奠定基础。 void swap(vector& v) { std::swap(_start, v....return *this; } 11.构造和析构函数的实现: //默认构造1: /*vector() { }*//如果这个默认构造{}内可以没有,只用它的初始化列表...,如list: 12.vector以及容器通用打印的实现: //vector专属的打印: template void Print(const vec::vector& t) {...{ std::cout << *it << " "; ++it; } std::cout << std::endl; } 四·vector模拟实现过程中遇到的问题总结

    3600

    C中实现TCP套接字

    如何在C中实现TCP套接字 最近一直出差,大家不好意思。文章更新的有点慢,希望大家包涵!!谢谢!!!今天讲工业现在用到最多的通讯协议。 TCP套接字用于服务器和客户端进程之间的通信。...服务器回复“这是服务器的消息”,并且通信终止。 指示 1、单击下面的小部件中的“运行”按钮,然后执行服务器的命令。如果成功创建了套接字,将显示消息“正在侦听传入的连接…”。...2、按下+按钮以打开另一个终端标签并执行客户端的命令。 3、在“客户端”选项卡中输入一条消息,该消息将发送到服务器。 4、该服务器的响应将在显示客户小号标签”。 ?...TCP_Server.c #include #include #include #include int...Closing the socket: close(client_sock); close(socket_desc); return 0; } TCP_client.c

    97520

    C++尝鲜:在C++中实现​​​LINQ!

    本篇介绍的主要内容是关于c++ linq的,可能很多读者对c++的linq实现会比较陌生,但说到C#的linq,大家可能马上就能对应上了。...没错,c++的linq就是在c++下实现类似C# linq的机制,本身其实就是在定义一个特殊的DSL,相关的机制已经被使用在c++20的ranges库,以及不知道何时会正式推出的execution库中,...一、从ranges示例说起 ranges是c++20新增的特性,很好的弥补了c++容器和迭代器实现相对其他语言的不便性。它的使用并不复杂。...我们将在下一章中探讨这部分的实现机制。...二、特殊的DSL实现 其实本质上来说, 这种实现很巧妙的利用了部分compiler time的特性,最终在c++中实现了一个从“代码->Compiler->Runtime”的一个DSL,后续我们也介绍到

    2K10

    技巧 | C++中实现类似instanceof的方法

    前言 C++有多态与继承,但是很多人开始学习C++,有时候会面临一个常见问题,就是如何向下转型,特别是不知道具体类型的时候,这个时候就希望C++ 可以向Java或者Python中有instanceof这个函数...,可实际上C++中没有。...但是别着急,其实C++中有两种简单的方法可以实现类似Java中的instanceof的功能。 在 C++ 中,确定对象的类型是编程中实际需求,使开发人员能够做出动态决策并执行特定于类型的操作。...无论是在编译时检查类型,还是在运行时动态标识对象类型,C++ 都提供了强大的机制来获取类型信息 使用typeid.name()方法 寻找实例的类类型,代码演示如下: 使用std::is_same方法 代码实现与运行效果如下...: 使用dynamic_cast dynamic_cast方法转型是C++中一种非常杰出的方法。

    20210

    《C++中动态数组的实现与探索》

    在 C++编程中,动态数组是一种非常重要的数据结构,它能够根据实际需求在运行时动态地调整大小,为程序员提供了极大的灵活性。...本文将深入探讨如何在 C++中实现动态数组,包括使用内置数据结构和自定义实现的方法,同时分析其性能特点和应用场景。 一、引言 在编程过程中,我们经常会遇到需要存储一组数据的情况。...二、C++内置动态数组实现——std::vector 1. std::vector 的基本用法 std::vector 是 C++标准库中提供的一种动态数组容器。...五、结论 在 C++中,实现动态数组有多种方法,既可以使用标准库中的 std::vector,也可以自定义实现。每种方法都有其特点和适用场景,我们需要根据实际需求进行选择。...无论是在处理大规模数据还是在实现复杂的数据结构时,动态数组都是一个非常有用的工具。希望本文能够帮助读者更好地理解和掌握 C++中动态数组的实现方法。

    19010

    原 c#中闭包的实现方法

    很多闭包实现成匿名函数(js也是表现成匿名函数的,其他的方法不清楚),3.0中引入了匿名函数,相应的也提供了闭包的支持。...在js里面是通过函数对象之间作用域链的引用关系实现,那么在c#中又是用什么方法实现的呢? 反编译代码: 编译后的代码生成了一个新的类,c#的闭包就是建立在这个类的基础上面的。...其中闭包中的变量作为类的公开成员变量,闭包函数自身作为成员,类型是internal。因为此类和闭包函数所在的类生成在一个同一个程序集中,而闭包流程中并不会使用这个类与其他程序集直接交流。...具体的调用过程 Main中: .method private hidebysig static void Main(string[] args) cil managed { .entrypoint...起始用字段i和方法'b__0'实例化了action,因而在main中调用的时候变量已经包含在action的参数里面带过去了。通过这种方法实现了变量生命周期的延长。

    1.7K60

    模拟实现C++中的string类(详细解析)

    学习C++,特别是C++中的STL部分,重点不是学习如何去使用STL,而是知道其底层原理是怎么样的,是怎么去实现的。因此,本篇文章带来的是对C++中的string的模拟实现。...一.模拟实现构造函数 对于构造函数,在官方库中,C99有下面种类:  我们主要实现的是 string(); string(const char* s); string(const string&...四.模拟实现string类对象修改操作 ①push_back() push_back的实现,相当于数据结构中的顺序表差不多,如果我们对顺序表的实现熟悉的话,实现push_back一点问题都没有。...在C/C++中,当小的类型于相较大的类型做运算时,小的类型会向大的类型提升,比如int跟double做运算时,int会提升为double。 其解决方法就是,将pos强制转换成int类型。...还有就是,在C++的string类的库中,end的类型就是size_t的,我们既然要模拟实现string,我们就遵循规则。那么我们该如何取解决这个问题呢? 好办!

    87020
    领券