序算法在编程领域中起着举足轻重的作用,在目标检索、机器学习、数值计算、图像处理等领域有着广泛。为了追本溯源,公众号特推出常用经典排序算法系列推文,让小伙伴们深入了解排序算法的实现原理,同时也提升matlab编程能力。
今天给大家的介绍的排序算法为:简单选择排序算法,它是排序算法中最基本的算法,下面就一起来看看该算的实现原理吧。
简单选择排序算法实现过程(以升序排列为例):
对于长度为N的无序数组A,设置排序位置标记loc,假设以A(1)为作为起始标记位置,即loc = 1,将A(1)与A(2)作比较,如果A(loc)>A(2),则loc=2,否则loc保持不变,然后将A(loc)与3至n的元素进行比较,找最小的元素,将最小的元素与A(1)进行交换,即完成一次遍历;按照以上方法遍历完所有元素,即可完成无序数组的排序。
matlab代码
主程序:main.m
format short;
clc;clear;
A = round(rand(1,10),2);
nA = simSelectR(A);
disp(['原始序列:',num2str(A)]);
disp(['选择排序:',num2str(nA)]);
简单选择排序函数:simSelectR.m
function A = simSelectR(A)
% 感谢关注:matlab爱好者
% 简单选择排序算法源代码
% 作者:matlab爱好者
len = length(A);
for w = 1:len
loc = w;
% 遍历len-w+1次
for v = w+1:len
if(A(loc)>A(v))
loc = v;
end
end
% 完成位置交换
tmp = A(w);
A(w) = A(loc);
A(loc) = tmp;
end
效果图