数据结构与算法(Dart)之选择排序(十三)

每次从未排序的部分选取最小(或最大)的元素,放到已排序部分的末尾。

开始默认第一个元素最小。

时间复杂度: O(n²), 不稳定

ini 复制代码
/// 选择排序
selectionSort(List<int> src) {
  for (int i = 0; i < src.length - 1; i++) {
    /// min记录最小值的下标
    int min = i;
    for (int j = i + 1; j < src.length; j++) {
      if (src[j] < src[min]) {
        min = j;
      }
    }

    /// 此时min已经保存最小值下标,将min换到最前面
    if (min != i) {
      int temp = src[i];
      src[i] = src[min];
      src[min] = temp;
    }
  }

  print("选择排序, src:$src \n");
}

void main() {
  selectionSort([36, 3, 4, 2, 1, 6, 5, 9, 7, 8, 10]);
}
相关推荐
王老师青少年编程9 分钟前
信奥赛C++提高组csp-s之拓扑排序详解
c++·算法·拓扑排序·csp·信奥赛·csp-s·提高组
kaikaile199519 分钟前
matlab计算流场
人工智能·算法·matlab
3GPP仿真实验室31 分钟前
【Python源码】6G:PyTorch OFDM 教学仿真平台
算法
xie_pin_an34 分钟前
C++ 从入门到进阶:核心知识与实战指南
java·c++·算法
我是个菜鸡.1 小时前
多模态算法面经准备
算法
AlenTech1 小时前
739. 每日温度 - 力扣(LeetCode)
算法·leetcode·职场和发展
MM_MS2 小时前
Halcon控制语句
java·大数据·前端·数据库·人工智能·算法·视觉检测
mit6.8242 小时前
山脉二分找中值|子集型回溯
算法
乃瞻衡宇2 小时前
Agent Skills 完全指南:让你的 AI Agent 拥有超能力
算法
mit6.8242 小时前
pair<int, TreeNode*> dfs
算法