zhuyuuyuhz 2015-09-26 14:25 采纳率: 100%
浏览 1877
已采纳

java选择排序使用swap()函数出现数组越界报错

 class SelectSort{
    public static void Swap(int[] arr,int i,int j){
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }

    public static void PrintArray(int[] Array){
        for(int i=0;i<Array.length;i++){
            System.out.print(" "+Array[i]);
        }
    }

    public static void SelectSort(int[] arr){
        for(int i=0;i<arr.length-1;i++){
            for(int j=i+1;j<arr.length;j++){
                if(arr[i]>arr[j]){                  
                    Swap(arr,arr[i],arr[j]);
                }               
            }
        }
    }

    public static void main(String[] args){
        int[] arr = {9,2,8,13,22,1};
        SelectSort(arr);
        PrintArray(arr);
    }   
}

/**
*@author 2015-09-26
*function:选择排序的练习和java中引用类型的用法
*问题:使用Swap()函数的时候,就会出现java.lang.ArrayIndexOutOfBoundsException问题
*目前还未解决,忧伤= =。
*/

  • 写回答

5条回答 默认 最新

  • havedream_one 2015-09-26 14:50
    关注

    Swap(arr,i,j);

    在有你的选择排序思想用的不对
    (1):将序列分成有序区和无序区,初始时有序区为空,无序区包括全部元素
    (2):每次从无序区中选择最小的元素将其与无序区第一个元素进行交换
    (3):重复(2),直到无序区没有元素
    public static void selectSort(int[] arr){
    int tmp = 0;
    int index = 0;
    for(int i = 0 ; i < arr.length ; i ++){
    index = i;
    //查找[i...length]中的最小值
    for(int j = i + 1; j < arr.length; j ++){
    if(arr[index] > arr[j]){
    index = j;
    }
    }
    //最小元素不是本身
    if(index != i){
    tmp = arr[index];
    arr[index] = arr[i];
    arr[i] = tmp;
    }
    }
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 用verilog实现tanh函数和softplus函数
  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 51寻迹小车定点寻迹
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站
  • ¥15 滑块验证码移动速度不一致问题