排序之选择排序

选择排序

工作原理:开启一个循环,每轮从未排序区间选择最小的元素,将其放到已排序区间的末尾。

eg: 4 1 3 1 5 2

step1. swap(4,1) 1 4 3 1 5 2

step2. swap(4,1) 1 1 3 4 5 2

step3. swap(3,2) 1 1 2 4 5 3

step4. swap(4,3) 1 1 2 3 5 4

step5. swap(5,4) 1 1 2 3 4 5

c++ 复制代码
#include<iostream>

using namespace std;

int main(){
    int size = 6;
    int nums[] = {4,1,3,1,5,2};
    for(int i = 0;i<size;i++){
        int min = i;
        for(int j = i+1;j<size;j++){
            if(nums[j] < nums[min]){
                min = j;
            }
        }
        int temp = nums[i];
        nums[i] = nums[min];
        nums[min] = temp;
    }
    for(int i = 0;i<6;i++){
        cout<<nums[i]<<" ";
    }
    return 0;
}
相关推荐
梦想的颜色16 分钟前
mongoTemplate + Java 增删改查基础介绍
数据结构·数据库·mysql
yu859395840 分钟前
MATLAB连续线性化模型预测控制(SL-MPC)
算法·机器学习·matlab
ytttr8731 小时前
基于ACADO工具包的自主车道跟踪与避障MPC控制
算法
隔壁大炮1 小时前
第一章_机器学习概述_03.机器学习_算法分类
算法·机器学习·分类
WolfGang0073211 小时前
代码随想录算法训练营 Day43 | 图论 part01
算法·深度优先
叶小鸡2 小时前
小鸡玩算法-力扣HOT100-堆
数据结构·算法·leetcode
何陋轩3 小时前
【重磅】悟空来了:国产AI编程助手深度测评,能否吊打Copilot?
人工智能·算法·面试
逸风尊者3 小时前
XGBoost模型工程使用
java·后端·算法
LUVK_3 小时前
第七章查找
数据结构·c++·考研·算法·408