我希望这个程序按字母顺序对混乱的单词进行排序,与字典进行比较,并与字典单词匹配。我按字母顺序打印出混乱,但即使我有打印行也不会打印字典单词。
public class i
{
public static void main(String[] args) throws Exception
{
if (args.length < 2 ) die("No dictionary");
BufferedReader dictionaryFile = new BufferedReader( new FileReader( args[0] ));
BufferedReader jumbleFile = new BufferedReader( new FileReader( args[1] ));
HashMap<String, ArrayList<String>> map = new HashMap<String, ArrayList<String>>();
ArrayList<String> jumbleWords = new ArrayList<String>();
ArrayList<String> dictionaryWords = new ArrayList<String>();
while(dictionaryFile.ready())
{
String dictWord = dictionaryFile.readLine();
dictionaryWords.add(dictWord);
}
while(jumbleFile.ready())
{
String word = jumbleFile.readLine();
//String canWord = toCanonical(word);
jumbleWords.add(word);
map.put(word, new ArrayList<String>());
}
Collections.sort(jumbleWords);
for(String dictionaryWord : dictionaryWords)
{
String canDictWord = toCanonical(dictionaryWord);
if(map.containsValue(canDictWord))
{
ArrayList<String> listOfWords = map.get(canDictWord);
listOfWords.add(dictionaryWord);
}
}
ArrayList<String> keysList = new ArrayList(map.keySet());
Collections.sort(keysList);
for(String key : keysList)
{
System.out.print(key);
ArrayList<String> list = map.get(key);
Collections.sort(list);
for(String word : list)
{
if (toCanonical(key).equals(toCanonical(word)))
System.out.print(word + " ");
}
System.out.println();
}
}
private static void die( String errmsg )
{
System.out.println( "\nFATAL ERROR: " + errmsg + "\n" );
System.exit(0);
}
private static String toCanonical( String word )
{
char[] letters = word.toCharArray();
Arrays.sort(letters);
return new String(letters);
}
}
答案 0 :(得分:2)
地图的值定义为ArrayList<String>
类型,但在下面的代码中,您尝试检查它是否包含常规String
。
if(map.containsValue(canDictWord)) {
// ...
}
这将始终返回false,因此println
无法正常工作的原因是因为地图的值ArrayList
将始终为空。
很难弄清楚你实际想要实现的目标,而且代码的格式化(或缺乏代码)会让它变得更难。您可能应该尝试使用字典单词作为键来制作地图,并将混乱的单词作为值列表。然后,您可以使用map.containsKey(toCanonical(jumbledWord))
并将混乱的单词添加到该键的值列表中。