0

0

c++怎么实现简单的排序演示_c++可视化基础【实战】

冰火之心

冰火之心

发布时间:2026-02-09 16:31:02

|

798人浏览过

|

来源于php中文网

原创

应优先使用 std::sort 实现数组排序,其底层为混合排序(introsort),平均时间复杂度 O(n log n),对小数组自动切换插入排序;注意正确传递迭代器范围,降序需传 std::greater(),自定义类型需提供比较逻辑,可视化调试宜用手动选择/插入排序并逐轮打印。

c++怎么实现简单的排序演示_c++可视化基础【实战】

std::sort 快速实现数组排序,别手写冒泡

90% 的简单排序需求,直接用 std::sort 就够了,没必要自己实现快排或归并——既容易出错,又没性能优势。它底层是混合排序(introsort),平均 O(n log n),且对小数组自动切到插入排序。

常见错误是传错迭代器范围:比如对 C 风格数组写成 std::sort(arr, arr + n - 1),漏掉最后一个元素;或者对 std::vector 写成 v.begin(), v.end() - 1,少排一个。

  • std::vector v = {3, 1, 4, 1, 5};,正确调用:std::sort(v.begin(), v.end())
  • 对 C 数组 int arr[5] = {3, 1, 4, 1, 5};,正确调用:std::sort(arr, arr + 5)
  • 要降序?加 std::greater()std::sort(v.begin(), v.end(), std::greater())

自定义类型排序必须重载 operator 或传比较函数

如果你的结构体或类不能直接比大小,std::sort 会编译失败,报错类似:invalid operands to binary expression ('MyStruct' and 'MyStruct')。这不是语法错,是缺少比较逻辑。

两种解法等效,但传比较函数更灵活(比如临时按不同字段排):

立即学习C++免费学习笔记(深入)”;

  • 在类内声明:bool operator
  • 或外部传 lambda:std::sort(vec.begin(), vec.end(), [](const auto&a, const auto&b) { return a.name
  • 注意 lambda 捕获列表为空([]),否则可能意外捕获局部变量导致未定义行为

可视化演示只需每轮输出一次状态,别真搞图形界面

所谓“可视化基础”,不等于要开 OpenGL 或 Qt 窗口。教学/调试场景下,控制台逐行打印数组当前状态,就是最有效、最易验证的可视化。

PathFinder
PathFinder

AI驱动的销售漏斗分析工具

下载

关键点是:别在 std::sort 内部插日志——它不提供 hook;得自己模拟排序过程,比如用选择排序手动实现并加打印:

for (int i = 0; i < n; ++i) {
    int min_idx = i;
    for (int j = i + 1; j < n; ++j)
        if (arr[j] < arr[min_idx]) min_idx = j;
    std::swap(arr[i], arr[min_idx]);
    // 打印当前轮次结果
    for (int x : arr) std::cout << x << " ";
    std::cout << "\n";
}
  • 选选择/插入排序而非快排,是因为步骤可预测、易跟踪
  • 每轮只改一个位置,输出清晰;快排的分区操作会让数组“跳变”,反而难理解
  • 如果用 std::sort,只能在排序前后各打一次,起不到“演示”作用

Windows 控制台中文乱码?先设 SetConsoleOutputCP(CP_UTF8)

std::cout 输出中文提示(如“第 1 轮:”)时,Windows 默认代码页是 GBK,而源文件通常是 UTF-8,不处理就会显示问号或方块。

不是编译问题,是运行时控制台编码不匹配。C++ 标准库本身不处理这个,得调 Windows API:

  • 开头加:#include ,然后调用 SetConsoleOutputCP(CP_UTF8)
  • 确保源文件保存为 UTF-8 无 BOM(VS 默认可能带 BOM,会导致编译警告甚至乱码)
  • Clang/GCC 下不用这步;MSVC 编译时加 /utf-8 参数可辅助,但控制台 CP 仍需手动设

真正麻烦的是跨平台一致性——Linux/macOS 终端默认 UTF-8,这段 Windows 专用代码得用 #ifdef _WIN32 包住,否则 Linux 下编译不过。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
视频后缀名都有哪些
视频后缀名都有哪些

视频后缀名都有avi、mpg、mpeg、rm、rmvb、flv、wmv、mov、mkv、ASF、M1V、M2V、MPE、QT、VOB、RA、RMJ、RMS、RAM、等等。更多关于视频后缀名的相关知识,详情请看本专题下面的文章,php中文网欢迎大家前来学习。

3595

2023.10.31

C++ Qt图形开发
C++ Qt图形开发

本专题专注于 C++ Qt框架在图形界面开发中的应用,系统讲解窗口设计、信号与槽机制、界面布局、事件处理、数据库连接与跨平台打包等核心技能,通过多个桌面应用项目实战,帮助学员快速掌握 Qt 框架并独立完成跨平台GUI软件的开发。

71

2025.08.15

C++ 图形界面开发基础(Qt方向)
C++ 图形界面开发基础(Qt方向)

本专题系统讲解 使用 C++ 与 Qt 进行图形界面(GUI)开发的核心技能,内容涵盖 Qt 项目结构、窗口组件、信号与槽机制、事件处理、布局管理、资源管理,以及跨平台编译与打包流程。通过多个小型桌面应用实战案例,帮助学习者掌握从界面设计到功能实现的完整 GUI 开发能力。

82

2025.12.05

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

399

2023.09.04

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

541

2023.09.20

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

302

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

196

2025.07.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

646

2023.08.02

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

127

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9万人学习

C 教程
C 教程

共75课时 | 4.6万人学习

C++教程
C++教程

共115课时 | 16.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号