直接选择排序

一.什么叫直接选择排序?

     在待排序记录1-n中选出最小的记录,将它与a[1]交换;第2趟,在待排序记录2-n中选出最小的记录,将它与a[2]交换;以此类推,第i趟在待排序记录i-n中选出最小的记录,将它与a[i]交换,使有序序列不断增长直到全部排序完毕。

二.排序步骤:

对下列数组进行排序:(21,5,32,64,85,63,25,32,11,22,44)

1.)定义变量x,y,h 及记录最小值的位置的变量small。
  int x,y,h;
  int small;
  int []a={21,5,32,64,85,63,25,32,11,22,44};
2.)排序实现:
1.默认从第一个数a[x]为最小值;
2. x将从第一个数,一直到倒数第二个数,在此期间 y每次从x+1开始找,一直到最后一个数;;
for( x=0;x<a.length-1;x++){//第一个数到倒数第二个数;
            small=x;
            for(y=x+1;y<a.length;y++){//第二个数到最后一个;
                if(a[small]>a[y]){
                    small=y;                
            }
}
        
图1
3. 当在y中没找到比默认值小的值时,将会x++,默认值即为最小值;
4. 当在y中找到最小值后,交换每次找到的最小值和默认最小值的位置。
if(small!=x){//如果在y中找到最小值,将最小值与a[x]交换;
                h=a[x];
                a[x]=a[small];
                a[small]=h;
            
            }
第一趟执行结果:
第一趟执行结果

三.完整程序:


public class SelectSort {
  //  选择排序法
    public static void main(String[] args) {
        int x,y,h;
        int small;
        int []a={21,5,32,64,85,63,25,32,11,22,44};
        
        for( x=0;x<a.length-1;x++){//第一个数到倒数第二个数;
            small=x;
            for(y=x+1;y<a.length;y++){//第二个数到最后一个;
                if(a[small]>a[y]){
                    small=y;                
                }
            }
            
            if(small!=x){//如果在y中找到最小值,将最小值与a[x]交换;
                h=a[x];
                a[x]=a[small];
                a[small]=h;
            
            }
        
        }
        for(int i:a){
        System.out.print(i+" ");
    }
}
}


结果展示:
结果展示
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 直接选择排序的基本思想 n个记录的文件的直接选择排序可经过n-1趟直接选择排序得到有序结果: ①初始状态:无序区为...
    葶寳寳阅读 498评论 0 4
  • 一、实验目的 学习使用 weka 中的常用分类器,完成数据分类任务。 二、实验内容 了解 weka 中 explo...
    yigoh阅读 8,638评论 5 4
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,923评论 18 139
  • 一、简介 选择排序法第一次扫描会找出最大或者最小值,放到正确的位置;第二次扫描会在剩余数据找出最大或者最小值,放到...
    野狗子嗷嗷嗷阅读 4,260评论 0 0
  • 咽喉既是正常呼吸必经之路,又是重要发声器。所以人人都要注意保护嗓子,尤其是教员、演员、广播员,更要注意。 首先要注...
    blueangelaa阅读 388评论 0 0