Java - 我的字母顺序排序算法并不总是按预期工作

标签 java arrays algorithm sorting alphabetical-sort

这是我的java代码。 (解释在最后)

import java.util.Scanner;
import java.util.Arrays;
/**
 *
 * @author Laksh
 */
public class Sort4 {
    public static void Swap(int[] array,int Swap1,int Swap2){
        int temporarySwapper;
        temporarySwapper=array[Swap1];
        array[Swap1]=array[Swap2];
        array[Swap2]=temporarySwapper;
    }
    public static void Swap(String[] array,int Swap1,int Swap2){
        String temporarySwapper;
        temporarySwapper=array[Swap1];
        array[Swap1]=array[Swap2];
        array[Swap2]=temporarySwapper;
    }
    public static String[] alphasort(String[] original, int level, int start, int end ){
        int swaps;
        int[] array=new int[original.length];
        for(int i=0;i<original.length;i++){
            array[i]=(int)original[i].charAt(level);
        }
        do{
            swaps=0;
            for(int i=start;i<end;i++){
                if(array[i]>array[i+1]){
                    Swap(original,i,i+1);
                    Swap(array,i,i+1);
                    swaps++;
                }
            }
        }while(swaps != 0);
        return Arrays.copyOfRange(original, start, end+1);
    }
    public static String repeat(String s,int times){
        String returnString="";
        for(int i=0;i<times;i++){
            returnString+=s;
        }
        return returnString;
    }

        public static void main(String[] args) {
        Scanner input=new Scanner(System.in);        
        System.out.println("Enter 5 Names:");
        int max=Integer.MIN_VALUE;
        String[] name=new String[5];
        for(int i=0;i<5;i++){
            name[i]=input.next();
            if(name[i].length()>max){
                max=name[i].length();
            }
        }
        for(int i=0;i<5;i++){
            if(name[i].length()<max){
                name[i]=name[i]+repeat(" ",max-name[i].length());
            }
        }

        String[] sorted=alphasort(name,0,0,name.length-1);
        for(String c:sorted){
            System.out.println(c);
        }

    }

}

为了阐明我面临的问题,我的代码依赖于查找 char 的 ascii 整数值,然后对整数数组进行排序。如果我尝试的字符串的第一个字母等于另一个字符串的第一个字母,代码将移动到第二个字母,依此类推。为了避免字符串索引越界,我使用“重复”方法在每个字符串的末尾添加足够的空格,使它们的长度都相同——因为相同长度的字符串会阻止这种情况。我面临的问题是排序正确,但在某些地方失败了。

例如,如果我传入“butter”和“butterfly”,这两个值将按输入顺序输出,与其他值相关,这些值已正确排序! 例如:

butter
cookie
butterfly
cookiemonster
ninja

排序为

butter       
butterfly    
cookie       
cookiemonster
ninja  

鉴于

butterfly
cookie
butter
cookiemonster
ninja

排序为

butterfly       
butter    
cookie       
cookiemonster
ninja

帮助我,因为我无法找到我的错误。

最佳答案

您只比较了每个单词的首字母,butterfly 和 butter 的单词顺序没有改变。

您必须将每个单词的每个字母与以下函数进行比较:

  int size = myArray.length;

  for(int i = 0; i<size-1; i++) {
     for (int j = i+1; j<myArray.length; j++) {
        if(myArray[i].compareTo(myArray[j])>0) {
           String temp = myArray[i];
           myArray[i] = myArray[j];
           myArray[j] = temp;
        }
     }

关于Java - 我的字母顺序排序算法并不总是按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55055340/

相关文章:

algorithm - 递归最长递增子序列的内存

java - JXLS 在每个命令中使用 if 命令时丢失行

Java HotSpot(TM) 64 位服务器 VM 警告、CentOS、SmartGit、SmartSvn

java - 如何阻止用户再次选择相同的号码?

algorithm - 合并两个排序的间隔列表

java - 朴素贝叶斯文本分类算法

java - 如何标记输出并去除零?

java - 应用程序服务器(如 jboss 或 weblogic)能否每 'n' 次调用一些方法

java - 如何创建 LinkedList<Object[]>[]?

java - 如何随机化一个数组以便一次打印 x% 的值?