首页
学习
活动
专区
工具
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可以通过一些优化措施实现稳定排序。

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

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

相关·内容

共1个视频
Serverless 架构上实现WordPress搭建
Kit
基于Serverless 架构上实现WordPress的搭建,方便又快捷。
共2个视频
数字华容道
Vaccae
使用C++ OpenCV开发的数字华容道及AI解题
共75个视频
《硅谷课堂-上》
腾讯云开发者社区
硅谷课堂是尚硅谷与腾讯云官方合作的项目,是一款基于微信公众号B2C模式的在线学习平台
共75个视频
《硅谷课堂-下》
腾讯云开发者社区
硅谷课堂是尚硅谷与腾讯云官方合作的项目,是一款基于微信公众号B2C模式的在线学习平台。
共17个视频
动力节点-JDK动态代理(AOP)使用及实现原理分析
动力节点Java培训
动态代理是使用jdk的反射机制,创建对象的能力, 创建的是代理类的对象。 而不用你创建类文件。不用写java文件。 动态:在程序执行时,调用jdk提供的方法才能创建代理类的对象。jdk动态代理,必须有接口,目标类必须实现接口, 没有接口时,需要使用cglib动态代理。 动态代理可以在不改变原来目标方法功能的前提下, 可以在代理中增强自己的功能代码。
共39个视频
动力节点-Spring框架源码解析视频教程-上
动力节点Java培训
本套Java视频教程主要讲解了Spring4在SSM框架中的使用及运用方式。本套Java视频教程内容涵盖了实际工作中可能用到的几乎所有知识点。为以后的学习打下坚实的基础。
共0个视频
动力节点-Spring框架源码解析视频教程-
动力节点Java培训
本套Java视频教程主要讲解了Spring4在SSM框架中的使用及运用方式。本套Java视频教程内容涵盖了实际工作中可能用到的几乎所有知识点。为以后的学习打下坚实的基础。
共0个视频
动力节点-Spring框架源码解析视频教程-下
动力节点Java培训
本套Java视频教程主要讲解了Spring4在SSM框架中的使用及运用方式。本套Java视频教程内容涵盖了实际工作中可能用到的几乎所有知识点。为以后的学习打下坚实的基础。
共29个视频
【动力节点】JDBC核心技术精讲视频教程-jdbc基础教程
动力节点Java培训
本套视频教程中讲解了Java语言如何连接数据库,对数据库中的数据进行增删改查操作,适合于已经学习过Java编程基础以及数据库的同学。Java教程中阐述了接口在开发中的真正作用,JDBC规范制定的背景,JDBC编程六部曲,JDBC事务,JDBC批处理,SQL注入,行级锁等。
共25个视频
uni-app云开发入门到实战
代码哈士奇
课程地址https://static-b5208986-2c02-437e-9a27-cfeba1779ced.bspapp.com 推荐使用腾讯云服务空间(能更好的搭配微信/qq小程序)
共10个视频
资深架构师谈Java面试系列第一季
架构风清扬
作为多年面试官从以往的面试经验中,逐步梳理相关的面试题进行分析讲解,帮助你快速梳理技术脉络
共26个视频
web前端系列教程-HTML零基础入门必备教程【动力节点】
动力节点Java培训
HTML基础语法,内容主要包括:HTML概述、W3C概述、B/S架构系统原理、table、背景色与背景图片、超链接、列表、表单、框架等知识点。通过该视频的学习之后,可以开发基本的网页,并且可以看懂别人编写的HTML页面。
共2个视频
手写docker系列
蓝胖子的编程梦
🐑 🐑 🐑 本系列教程主要是为了弄清楚容器化的原理,纸上得来终觉浅,绝知此事要躬行,理论始终不及动手实践来的深刻,所以这个系列会用go语言实现一个类似docker的容器化功能,最终能够容器化的运行一个进程。
共2个视频
腾讯金融云银行业数字原生技术论坛
腾讯金融云小助手
“ 数字原生“之于商业银行的数字化转型战略,是一个发展阶段后的”目标形态“, 也是转型过程中的方法路径。 本次我们共展示“云原生”主题专场及“数实融合”主题专场展现‘数字原生“的腾讯见解。
共22个视频
JavaWeb阶段入门教程-EL表达式+JSP【动力节点】
动力节点Java培训
通过本课程的学习,使大家掌握JSP开发,充分认知JSP在实际项目开发中的重要作用。 jsp从表现上看更像是前端组件,只是传统的html代码加入了java脚本的综合操作。但是在本质上,jsp同时又是servlet。
共20个视频
动力节点-Maven进阶篇之Maven多模块管理教程
动力节点Java培训
Maven的主要目标是希望开发人员能在最短的时间内理解开发的完整状态。为了达到这个目标,Maven在下面几个方面做出了努力:简化构建过程、统一构建体系、提供高质量的项目信息、提供开发的最佳实践指南、实现透明的向新特性的迁移、简化构建过程。使用Maven不须要知道一些潜在的或底层的机制,Maven屏蔽了非常多细节
共41个视频
【全新】RayData Web功能教程
RayData实验室
RayData Web:一款基于B/S架构的,面向企业级用户的专业可视化编辑工具,具有强大的项目管理和编辑能力,支持更精细的权限分配、更自由的项目搭建、更全面的开发拓展。应用于各种数据分析与展示场景中,针对行业提供优质的可视化解决方案。
领券