数据结构与算法(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]);
}
相关推荐
坚持编程的菜鸟16 分钟前
互质数的个数
c语言·算法
ICscholar19 分钟前
具身智能‘Affordance‘理解
人工智能·学习·算法
wangwangmoon_light26 分钟前
1.2 LeetCode总结(线性表)_双指针
算法·leetcode·职场和发展
琢磨先生David32 分钟前
Java算法每日一题
java·开发语言·算法
重生之后端学习37 分钟前
114. 二叉树展开为链表
java·数据结构·算法·链表·职场和发展·深度优先
天一生水water1 小时前
基于FFT的频域故障诊断
人工智能·算法·智慧油田
石去皿1 小时前
数据结构与算法面试核心考点精要
java·算法·面试
今儿敲了吗1 小时前
18| 差分数组
c++·笔记·学习·算法
Bear on Toilet1 小时前
BFS_FloodFill_46 . 腐烂的橘子问题
数据结构·c++·算法·leetcode·宽度优先
大模型玩家七七1 小时前
关系记忆不是越完整越好:chunk size 的隐性代价
java·前端·数据库·人工智能·深度学习·算法·oracle