我遇到的主要问题是弄清楚如何将特定的字符串传递给存储桶类,以将每个字符串分成各自的存储桶。这是一项任务,我被困住了。我不需要解决方案,仅需要一些帮助即可将我指出正确的方向。
注意:我必须在存储桶类中使用存储桶数组列表和链接列表
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();
}
}
}
答案 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))
我没有在此处放置任何代码,因为这是一项作业