配列内の特定の単語に対して、連続する子音の最大数を見つけようとしています。コメントした途中にwhileループがありますが、何らかの理由で実行されません。誰かが理由を知っていますか?また、String[] 単語のサブ配列を見つけようとしているため、int スペースがあることに気付くかもしれません。どうすればそれを行うことができますか?
import java.io.*;
import java.util.*
import java.util.Arrays;
public class Main
{
public static void main (String[] args)
{
System.out.print("Please enter a phrase to translate: ");
Scanner scan = new Scanner(System.in);
String str = scan.nextLine();
String[] words = str.split("\\s+");
int spaces = (word.length - 1);
for (int i = 0; i < words.length; i++)
{
String a = words[i].substring(0,1);
int k = a.length();
int n = words[i].length();
if (!(a.contains("a") || a.contains("e") || a.contains("i") || a.contains("o") || a.contains("u")))
{
while (k < 5) // start while
{
if (n > k)
{
a = words[i].substring(0,k);
k = k + 1;
}
}
} // end while
if (words[i].startsWith("a") || words[i].startsWith("e") || words[i].startsWith("i") || words[i].startsWith("o") || words[i].startsWith("u"))
{
System.out.print(words[i] + "way");
}
else if (!(a.contains("a") || a.contains("e") || a.contains("i") || a.contains("o") || a.contains("u")))
{
String answer = words[i].substring(k,n);
System.out.print(answer + a + "ay");
}
}
}
}