A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

  1. class  Test
  2. {
  3.         public static void main(String[] args)
  4.         {
  5.                 int[]arr={3,5,6,7,1,9,12};
  6.                 selectSort(arr);
  7.         }

  8.         public static void selectSort(int[] arr)
  9.         {
  10.                 for(int x=0;x<arr.length-1;x++)
  11.                 {
  12.                         for(int y=x+1;y<arr.length;x++)
  13.                         {
  14.                                 if(arr[x]>arr[y])
  15.                                 swap(arr,x,y);
  16.                         }
  17.                 }
  18.         }

  19.         public static void swap(int[] arr,int a,int b)
  20.         {
  21.                 int temp=arr[a];
  22.                 arr[a]=arr[b];
  23.                 arr[b]=temp;
  24.         }


  25. }
复制代码

8 个回复

倒序浏览
错误是这样的。该怎么解决呢?{:3_47:}

QQ截图20140317190841.png (2.56 KB, 下载次数: 75)

QQ截图20140317190841.png
回复 使用道具 举报
下标越界
回复 使用道具 举报
本帖最后由 nicholyx 于 2014-3-17 19:30 编辑

数组下标越界了,改正之后如下,加上了打印数组语句

  1. class  Test
  2. {
  3.         public static void main(String[] args)
  4.         {
  5.                 int[]arr={3,5,6,7,1,9,12};
  6.                 printArray(arr);
  7.                 selectSort(arr);
  8.                 printArray(arr);
  9.         }

  10.         public static void selectSort(int[] arr)
  11.         {
  12.                 for(int x=0;x<arr.length-1;x++)
  13.                 {
  14.                         for(int y=x+1;y<arr.length;y++)   //最后的语句是y++,原来的是x++
  15.                         {
  16.                                 if(arr[x]>arr[y])
  17.                                 swap(arr,x,y);
  18.                         }
  19.                 }
  20.         }

  21.         public static void swap(int[] arr,int a,int b)
  22.         {
  23.                 int temp=arr[a];
  24.                 arr[a]=arr[b];
  25.                 arr[b]=temp;
  26.         }

  27.                 public static void printArray(int[] arr) {   //数组打印语句
  28.                 System.out.print("[");
  29.                 for(int i = 0; i < arr.length; i++) {
  30.                         if(i < arr.length - 1) {
  31.                                 System.out.print(arr[i] + ", ");
  32.                         } else {
  33.                                 System.out.println(arr[i] + "]");
  34.                         }                                
  35.                 }
  36.         }
  37. }
  38. /*
  39. 输出结果:
  40. [3, 5, 6, 7, 1, 9, 12]
  41. [1, 3, 5, 6, 7, 9, 12]
  42. */
复制代码

评分

参与人数 1技术分 +1 收起 理由
菜小徐 + 1

查看全部评分

回复 使用道具 举报 1 0

再具体点呗,具体是哪个地方产生的越界的?
回复 使用道具 举报
  1. for(int x=0;x<arr.length-1;x++)
  2.                 {
  3.                         for(int y=x+1;y<arr.length;x+)//应该是y++不是x++当外层for循环x取到最大值时在内循环 又加1,下面访问时会角标越界
  4.                         {
  5.                                 if(arr[x]>arr[y])
  6.                                 swap(arr,x,y);
  7.                         }
  8.                 }
复制代码

评分

参与人数 1技术分 +1 收起 理由
菜小徐 + 1

查看全部评分

回复 使用道具 举报 2 0
  1. class  Test
  2. {
  3.         public static void main(String[] args)
  4.         {
  5.                 int[]arr={3,5,6,7,1,9,12};
  6.                 selectSort(arr);
  7.                 sop(arr);
  8.         }
  9. static void sop(int [] arr)
  10. {
  11.                 for(int i=0;i<arr.length;i++)
  12.                 System.out.println(arr[i]);
  13.         }

  14.         public static void selectSort(int[] arr)
  15.         {
  16.                 for(int x=0;x<arr.length-1;x++)
  17.                 {
  18.                         for(int y=x+1;y<arr.length;y++)//这里是y++
  19.                         {
  20.                                 if(arr[x]>arr[y])
  21.                                 swap(arr,x,y);
  22.                         }
  23.                 }
  24.         }

  25.         public static void swap(int[] arr,int a,int b)
  26.         {
  27.                 int temp=arr[a];
  28.                 arr[a]=arr[b];
  29.                 arr[b]=temp;
  30.         }
  31.         

  32. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
菜小徐 + 1

查看全部评分

回复 使用道具 举报 1 0

看到错误了。。。一个低级错误{:3_48:}
回复 使用道具 举报
nicholyx 发表于 2014-3-17 19:25
数组下标越界了,改正之后如下,加上了打印数组语句

嗯嗯!很详细!:handshake
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马