加入收藏 | 设为首页 | 会员中心 | 我要投稿 应用网_丽江站长网 (http://www.0888zz.com/)- 科技、建站、数据工具、云上网络、机器学习!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

C++和Java实现基本的选择排序和常见问题

发布时间:2021-12-05 17:06:58 所属栏目:PHP教程 来源:互联网
导读:一、选择排序的基本思想: 首先,找到数组中最小的元素,其次将它和数组第一个元素交换位置(如果第一个元素就是最小元素则和自己交换),然后在剩下的元素中找到最小的元素,将它与数组第二个元素交换位置。如此循环,直到将整个数组排序。这种方法叫做选择

一、选择排序的基本思想:
 
       首先,找到数组中最小的元素,其次将它和数组第一个元素交换位置(如果第一个元素就是最小元素则和自己交换),然后在剩下的元素中找到最小的元素,将它与数组第二个元素交换位置。如此循环,直到将整个数组排序。这种方法叫做选择排序。
 
       对于长度为N的数组,选择排序需要大约N^2/2次比较和N次交换
 
C++代码实现:
 
#include<iostream>
 
using namespace std;
template<typename T>
void selectionSort(T a[],int N) {
        for (int i = 0; i < N; i++) {
       
            int min = i;
            for (int j = i + 1; j < N; j++)
                if (a[min] > a[j])
                    min = j;
                    swap(a[i],a[min]);
        }
    }
 
 
int main() {
    int arr[10] = { 10,5,2,6,3,4,7,9,8,1 };
    selectionSort(arr,10);
    for (int i = 0; i < 10; i++)
        cout << arr[i] << " ";
    cout << endl;
    system("pause");
 
}
 
Java代码实现:
 
package selectionsort;
 
public class SelectionSort {
    public static void selectionSort(Comparable[] a){
        int N=a.length;
        for(int i=0;i<N;i++){
            int min=i;
            for(int j=i+1;j<N;j++)
                if(less(a[j],a[min]))
                    min=j;
                exch(a,i,min);
        }
    }
   
    private static boolean less(Comparable v,Comparable w){
        return v.compareTo(w)<0;
    }
   
    private static void exch(Comparable[] a,int i,int j){
        Comparable t=a[i];a[i]=a[j];a[j]=t;
    }
   
   
   
    public static void main(String[] args) {
          Integer[] arr = {4,7,8,3,9,5,6,1,2};
          SelectionSort.selectionSort(arr);
          for( int i = 0 ; i <arr.length ; i ++ ){
              System.out.print(arr[i]);
              System.out.print(' ');
          }
       
    }
}
 
二、常见错误
 
问题描述:运行完程序后发现第一个元素与第二个元素没有排好序。如下图
 
 
 
解决:对于代码selectionSort方法中,if判断语句不要嵌套进第二个for循环中。
 
因为第二个for循环是为了寻找与i交换位置的元素,要循环找到后,才能判断它与i的大小关系。

(编辑:应用网_丽江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读