1-- 选择排序之简单选择排序

(1)简单选择排序和堆排序的基本思想是什么?


(2)选择排序的本质是什么


一、简单选择排序

          简单选择排序最佳情况下,记录移动次数为0, 最坏情况下,记录移动次数n-1。外层循环进行了n-1趟选择,第i趟选择要进行n-i次比较,忽略移动记录时间(为一常数)。所以总时间是(n-1)*(n-i)=n^2-(i+1)*n+i时间复杂度为O(n^2)。

            在排序的过程中,

第一趟排序后,A[1]已经有顺序了,需要排序的是A[2...n]。

                这是一个待排序序列中记录不断减少的递归过程。我们每次都是从待排序记录中选择最小的那个记录作为待排序的首元素进行交换。可以用递归进行简单选择排序。


    //简单选择排序
    public void simpleSelectionSort1(int a[], int n){
        //进行n次选择,n为数组的长度
        for(int i=0;i<n;i++){
            int index=i ,j ,temp=a[i];
            //每次选择出当前待排序记录中的最小/大记录
            //n-1表示下表,n-1-i进行第i次选择的起始位位置
            for(j=i;j<n-1;j++){
                if(a[j+1]<a[j]){
                    index=j;
                    temp=a[j];
                }
            }
            if(a[j]>temp)index=j;
            //最小值交换
            if(index!=i){
                a[i]=a[i]+a[index];
                a[index]=a[i]-a[index];
                a[i]=a[i]-a[index];
            }
        }
        
    }



       


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
简单选择排序是一种排序算法,它的基本思想是从待排序的数据序列中,通过不断地选择最小(或最大)的元素,将其放在已排序序列的末尾,直到所有元素都排好序为止。 具体实现方法如下: 1. 首先,设定一个指针i,表示当前已排序的序列的末尾位置。初始化i为0。 2. 从第i个位置开始,遍历整个序列,找出最小的元素,并记录其位置为minIndex。 3. 将第minIndex个元素与第i个元素交换位置,即将最小的元素放在已排序序列末尾。 4. 将指针i往后移动一位,即i++。 5. 重复步骤2~4,直到i达到序列的末尾。 简单选择排序的时间复杂度为O(n^2),其中n为待排序序列的长度。它是一种比较简单但效率较低的排序算法,适用于小规模的数据排序。 举一个简单选择排序的例子:对数组[5, 3, 8, 2, 1]进行排序。 首先,指针i为0。 遍历序列,找出最小元素1的位置,即minIndex为4。 将第4个元素1与第0个元素5交换位置。 此时数组变为[1, 3, 8, 2, 5],已排序序列为[1]。 指针i向后移动一位,即i为1。 再次遍历序列,最小元素为2,位置为3。 将第3个元素2与第1个元素3交换位置。 此时数组变为[1, 2, 8, 3, 5],已排序序列为[1, 2]。 指针i向后移动一位,即i为2。 再次遍历序列,最小元素为3,位置为3。 将第3个元素3与第2个元素8交换位置。 此时数组变为[1, 2, 3, 8, 5],已排序序列为[1, 2, 3]。 指针i向后移动一位,即i为3。 再次遍历序列,最小元素为5,位置为4。 将第4个元素5与第3个元素8交换位置。 此时数组变为[1, 2, 3, 5, 8],已排序序列为[1, 2, 3, 5]。 指针i向后移动一位,即i为4。 再次遍历序列,最小元素为8,位置为4,没有需要交换的元素。 排序结束,最终数组为[1, 2, 3, 5, 8]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值