C++ STL中sort()原理浅解

2024-05-13 20:58
文章标签 c++ 原理 stl sort 浅解

本文主要是介绍C++ STL中sort()原理浅解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为什么会想要写这篇微博,主要发现在算法题中,很多题目都要使用到sort()来对数组进行一个排序,然后对其进行别的操作的时候会简单很多。所以就总结一下sort()的原理,以后有什么问题也可以追根溯源的解决一下,况且排序也是算法中重要的的组成部分之一,所以研究研究有利无害。sort()的使用方法为sort(begin,end),在一般的编程之中可以直接带入容器的begin()和end()函数来对,容器进行遍历。其函数包含在头文件<algorithm>中,其组成方面主要有两中排序方法(1)插入排序(2)快速排序。STL中定义了一个SORT_MAX变量来进行判断,如果大于SORT_MAX就使用快排,否则使用插排。

1、插入排序
插入排序的顺序如下,即按照顺序,从第一个数开始向后面依次遍历,寻找后面的元素在前面元素的位置,然后将数字插入进去,所以很容易知道插入排序的时间复杂度为O(n^2)次方,其实现程序如下:
void Insert_Sort(int *num,int n){int tmp=0;for(int i=0;i<n;i++){tmp=num[i];int j=i-1;while(j>=0&&tmp<num[j]){//将已经排序的数组和数本身相比如果比它大则将数组向后移num[j+1]=num[j];j--;}num[j+1]=tmp;}
}

2快速排序:
快速排序是一种对于冒泡排序的方法的一种改进,冒泡排序是将两个相邻元素进行交换,而快速排序在此基础上使用了二分法对数组进行操作,确定一个基数的位置,然后对基数右侧的都是比基数大的数字,而左侧都是比它小的数字,然后再进行递归排序。但快速排序并不是一个稳定的排序的方法,其时间复杂度并不是确定的,其平均排序时间复杂度为O(nlogn),但当情况特殊时,其最差的时间复杂度为O(n^2)和冒泡排序相同,其基本排序的规则如下:

所以其实现要使用递归调用,其实现代码如下:
int a[101]
void Quicks_Sort(int begin,int end){//带入开始位置和结束位置if(begin>end)//若开始大于结束return;int tmp=a[begin];//确定基数int i=begin;int j=end;while(i!=j){while(a[j]>=tmp&&j>i)//寻找比基数小的数j--;while(a[i]<=tmp&&j>i)//寻找比基数大的数i++;if(j>i){//交换两者int t=a[i];a[i]=a[j];a[j]=t;}}a[begin]=a[i];//交换基数和其位置a[i]=tmp;Qiicks_Sort(begin,i-1);//左侧迭代Qicks_Sort(i+1,end);//右侧迭代
}

其中需要先排右侧再排左侧,否则当某些情况下,当左侧先和右侧到达同一位置的时候排序会出现问题,其具体例子请见下面的博客:http://blog.csdn.net/w282529350/article/details/50982650
例子中出现了后面j需要小于i的情况,所以排序出错,最后需要提一下上面的程序大部分都是c实现的,而真正的STL源码中应该是用迭代器或者用迭代器操作符重载实现的,并非STL源码。

这篇关于C++ STL中sort()原理浅解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/986811

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

MyBatis-Plus 与 Spring Boot 集成原理实战示例

《MyBatis-Plus与SpringBoot集成原理实战示例》MyBatis-Plus通过自动配置与核心组件集成SpringBoot实现零配置,提供分页、逻辑删除等插件化功能,增强MyBa... 目录 一、MyBATis-Plus 简介 二、集成方式(Spring Boot)1. 引入依赖 三、核心机制