Java - 使用字符串合并排序

标签 java sorting merge mergesort indexoutofboundsexception

在这个程序中,我使用 mergeSort 对奥运奖牌进行排序。

我的代码似乎有点不对劲,因为有时它会给我一个 java.lang.ArrayIndexOutOfBoundsException,有时却不会。


一些背景解释:

我有一种方法可以随机生成奥运国家和他们在记分牌上获得的奖牌。以以下形式返回结果的 String[] 数组:

CAN 1 1 1

美国 1 1 2

GBR 0 0 1

中国 0 0 2


然而,记分牌需要按金牌、银牌和铜牌的降序排列。所以它必须是这样的:

美国 1 1 2

CAN 1 1 1

中国 0 0 2

GBR 0 0 1

使用冒泡排序和快速排序可以很好地对棋盘进行排序,但归并排序则不行。有时它会很好,但更多时候它会给我 ArrayIndexOutOfBoundsException。

public static void main(String[] args) {    

  Olympic_Results score = new Olympic_Results();

  //print a return value of an array    

  String[] countries = score.OlympicResult(7); //input how many game results
  mergeSort(countries, 0, countries.length - 1);
  for (String value:countries)
  System.out.println(value);
}

public static void mergeSort(String array[], int lo, int n) {
  int low = lo;
  int high = n;
  if (low >= high) {
    return;
  }

  int middle = (low + high) / 2;
  mergeSort(array, low, middle);
  mergeSort(array, middle + 1, high);
  int end_low = middle;
  int start_high = middle + 1;
  while ((lo <= end_low) && (start_high <= high)) {
    if ((array[low].substring(4,8)).compareTo(array[high].substring(4,8)) > 0) {
      low++;
    } 

    else {
      String Temp = array[start_high];
      for (int k = start_high - 1; k >= low; k--) {
        array[k + 1] = array[k];
      }
      array[low] = Temp;
      low++;
      end_low++;
      start_high++;
    }
  }
}  

知道为什么这段代码不能正常工作吗?谢谢!

最佳答案

我认为你把数组分成几部分太深入了:

if (low >= high) {
    return;
    }

尝试在长度为 1 时停止并开始修复它。

if (high - low <=1) {
    return;
    }

顺便说一句,如果长度为 2,那么您可以就地比较值并立即返回已经排序的值。

UPD

你似乎添加了太多具有相似名称的变量并且在其中迷失了自己:)..

这看起来不正确:

while ((lo <= end_low) && (start_high <= high)) {

关于Java - 使用字符串合并排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15900457/

相关文章:

visual-studio-2010 - 使用 hg 将具有存储库的不同项目 merge 为一个解决方案?

java - 将自定义值添加到外部绑定(bind)(JAXB - MOXY 实现)

java - 如何通过选择行并单击“删除”使 Swing 从表中删除条目?

java - 我坚持以递归方式实现基数排序

java - 对包含相对文件名的字符串数组进行排序

mercurial - 当变更集很小时,Mercurial 是否能更好地 merge 文件?

java - Hibernate (hbm) - 合并容器对象后使用 where 子句刷新集合

java - Derby 的另一个实例可能已经使用嵌入式数据库启动了数据库

java - Guava - map 支持的 Guava 功能

java - Java 外部排序