字符串的Java Bucket Sort程序

时间:2018-07-09 06:29:22

标签: java string bucket-sort

我遇到的主要问题是弄清楚如何将特定的字符串传递给存储桶类,以将每个字符串分成各自的存储桶。这是一项任务,我被困住了。我不需要解决方案,仅需要一些帮助即可将我指出正确的方向。

注意:我必须在存储桶类中使用存储桶数组列表和链接列表

import java.util.*;
import java.io.*;

public class Bucket {
    private char minInitial;
    private char maxInitial;
    private LinkedList<String> list;

    public Bucket (char min, char max) {

        minInitial = min;
        maxInitial = max;
        list = new LinkedList<String>();

    }

    public static void main (String args[]) {

        /* There are usually 8 for the entire alphabet because letters like c and s have more words for them than others */
        ArrayList<Bucket> buckets = new ArrayList<>(8);

        buckets.add(new Bucket('a', 'b'));
        buckets.add(new Bucket('c', 'c'));
        buckets.add(new Bucket('d', 'f'));
        buckets.add(new Bucket('g', 'k'));
        buckets.add(new Bucket('l', 'o'));
        buckets.add(new Bucket('p', 'r'));
        buckets.add(new Bucket('s', 's'));
        buckets.add(new Bucket('t', 'z'));


        File inFile;

        PrintWriter outFile;
        try {

            inFile = new File("input.txt");//input.txt file has the words sepepatated by comma "cat,dog,boy,bye"

            String path = inFile.getAbsolutePath();

            //outFile = new PrintWriter("output.txt");


            System.out.println("File Name:  "+ inFile +  "File Path: " + path);

            //System.out.println("File Name: " + outFile);

            Scanner fileScan = new Scanner(inFile);

            String inputFile="";

            while (fileScan.hasNext()) {

                inputFile = fileScan.next();
                System.out.println(inputFile);
            }


            String arrayString[] = inputFile.split(",");

            Arrays.sort(arrayString); //sorts the strings alphabetically

            for (int i =0; i<arrayString.length; i++) {
                System.out.println("List elem " + i + ": " +arrayString[i]);
                //traverses every element
            }

            System.out.println(Arrays.toString(arrayString));


            List listString = Arrays.asList(arrayString);

            System.out.println(listString);


        }
        catch (FileNotFoundException e) {
            System.out.println("! ! ! File Not Found ! ! !");
            e.printStackTrace();
        }
    }
}

2 个答案:

答案 0 :(得分:0)

如果您使用的是Java 8,则可以执行以下操作,在相应的存储桶中添加单词:

Arrays.stream(arrayString)
.forEach(word -> buckets.stream()
    .filter(bucket -> bucket.minInitial <= word.charAt(0) && word.charAt(0) <= bucket.maxInitial)
    .findFirst().ifPresent(bucket -> bucket.list.add(word)));

答案 1 :(得分:0)

我不建议在桶中混合字母。 您不应像以前那样进行任何排序:

  

Arrays.sort(arrayString); //按字母顺序对字符串进行排序

简单算法:
1.找到最长字符串的长度(O(n))
2.从上述长度开始再返回,在每次迭代中,将字符串放入存储桶中(如对数字进行存储桶排序)(O(Length * n))

我没有在此处放置任何代码,因为这是一项作业