C++ 选择排序

基本原理

选择排序的原理其实和冒泡排序很像,都是两层循环嵌套:

  • 设第一个元素为“标兵”,“标兵”的值为最小值,index 为最小值的 index 。
  • 遍历第一个元素之后的所有元素,若找到更小的值,则更新最小值和 index 。
  • 交换“标兵”和最小值,实现将最小值放在第一位,“标兵”后移,更新“标兵”。
  • 重复以上循环,直至遍历完毕。

以下 gif 参考https://blog.csdn.net/L_PPP/article/details/108498581
在这里插入图片描述

代码实现

#include <iostream>
#include <string>

using namespace std;

int main(){
    int array[10] = {1, 6, 8, 7, 9, 4, 3, 0, 2, 5};
    int len = sizeof(array) / sizeof(array[0]);
    int min_num = 0;  // 最小值
    int min_index = 0;  // 每一轮比较的最小值索引

    for (int i = 0; i < len; i++){
        min_num = array[i];
        min_index = i;
        for (int j = i + 1; j < len; j++){
            if (array[j] < min_num){
                min_num = array[j];
                min_index = j;  // 更新最小值的位置
            }
        }

        int temp = array[min_index];
        array[min_index] = array[i];
        array[i] = temp;
    }

    for (int i = 0; i < len; i++){
        cout << array[i] << " ";
        }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Drogon是一个基于C++14/17的Http应用框架,使用Drogon可以方便的使用C++构建各种类型的Web应用服务端程序。 本版本库是github上Drogon工程的镜像库。Drogon是作者非常喜欢的美剧《权力的游戏》中的一条龙的名字(汉译作卓耿),和龙有关但并不是dragon的误写,为了不至于引起不必要的误会这里说明一下。 Drogon是一个跨平台框架,它支持Linux,也支持macOS、FreeBSD,和Windows。它的主要特点如下: 1、网络层使用基于epoll(macOS/FreeBSD下是kqueue)的非阻塞IO框架,提供高并发、高性能的网络IO。详细请见TFB Tests Results; 2、全异步编程模式; 3、支持Http1.0/1.1(server端和client端); 4、基于template实现了简单的反射机制,使主程序框架、控制器(controller)和视图(view)完全解耦; 5、支持cookies和内建的session; 6、支持后端渲染,把控制器生成的数据交给视图生成Html页面,视图由CSP模板文件描述,通过CSP标签把C++代码嵌入到Html页面,由drogon的命令行工具在编译阶段自动生成C++代码并编译; 7、支持运行期的视图页面动态加载(动态编译和加载so文件); 8、非常方便灵活的路径(path)到控制器处理函数(handler)的映射方案; 9、支持过滤器(filter)链,方便在控制器之前执行统一的逻辑(如登录验证、Http Method约束验证等); 10、支持https(基于OpenSSL实现); 11、支持websocket(server端和client端); 12、支持Json格式请求和应答, 对Restful API应用开发非常友好; 13、支持文件下载和上传,支持sendfile系统调用; 14、支持gzip/brotli压缩传输; 15、支持pipelining; 16、提供一个轻量的命令行工具drogon_ctl,帮助简化各种类的创建和视图代码的生成过程; 17、基于非阻塞IO实现的异步数据库读写,目前支持PostgreSQL和MySQL(MariaDB)数据库; 18、基于线程池实现sqlite3数据库的异步读写,提供与上文数据库相同的接口; 19、支持ARM架构; 20、方便的轻量级ORM实现,支持常规的对象到数据库的双向映射操作; 21、支持插件,可通过配置文件在加载期动态拆装; 22、支持内建插入点的AOP
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值