对于类,我需要对文本文件执行多向排序。具体来说,我需要按元音计数,然后按长度组织单词。我的问题在于按元音量对数组进行排序。
我试图做的是迭代每个单词并计算该单词的元音。根据元音的数量,它会被添加到相应的队列中。
private static void vowelQueues(String[] words) {
Queue<String> noVowel = new LinkedList<String>();
Queue<String> oneVowel = new LinkedList<String>();
Queue<String> twoVowel = new LinkedList<String>();
Queue<String> threeVowel = new LinkedList<String>();
Queue<String> fourVowel = new LinkedList<String>();
Queue<String> fiveVowel = new LinkedList<String>();
Queue<String> sixVowel = new LinkedList<String>();
Queue<String> sevenVowel = new LinkedList<String>();
Queue<String> eightVowel = new LinkedList<String>();
Queue<String> nineVowel = new LinkedList<String>();
Queue<String> tenVowel = new LinkedList<String>();
char ch;
String vowelHolder = "";
int numVowels = 0;
for (String word : words) {
for (int i = 0; i < word.length(); i++) {
ch = word.charAt(i);
if (ch == 'a' || ch == 'e' || ch == 'i' || ch == 'o' || ch == 'u') {
numVowels++;
if (numVowels == 1) {
oneVowel.add(word);
numVowels = 0;
} else if (numVowels == 2) {
twoVowel.add(word);
numVowels=0;
} else if (numVowels == 3) {
threeVowel.add(word);
numVowels=0;
}
}
}
}
System.out.print(oneVowel); //These are test output statements
System.out.print(twoVowel);
System.out.println(threeVowel);
}
问题是包含元音的所有单词都会添加到oneVowel队列中,其余单词保持为空。我认为这是因为一旦第一个if语句将整个单词添加到第一个队列,numVowels就会递增。
我如何制作它以便所有单词中的元音和然后将其添加到它的相应队列?
答案 0 :(得分:2)
发生这种情况是因为当任何条件为真时,您将变量numVowels赋值为零。您的numVowels变量永远不会增加,并且始终第一个条件变为true。因此,只在oneVowel队列中添加元素。
File "[DATA EXPUNGED]", line 14, in <module>
playtts("HELLO THERE")
File "[DATA EXPUNGED]", line 12, in playtts
winsound.PlaySound('temp.wav', winsound.SND_FILENAME | winsound.SND_NOSTOP | winsound.SND_NODEFAULT)
RuntimeError: Failed to play sound
>>>