public class LongWord {
public static void main(String args[]) {
String text = "my brother is taller than me@1233334. I always a short man,but smart than him";
// Find the longest word in the String
String[] words = text.split("\\s");
String longestWord = "";
for (int i = 1; i < words.length; i++) {
int firstLen = words[i - 1].length();
int secondLen = words[i].length();
if (firstLen <= secondLen) {
longestWord = words[i];
}
}
System.out
.println("===================================================\nLongest Word:::: \n");
System.out.println(longestWord);
}
}
//这是查找语句中最长单词的示例程序。所以输出应该是“me @ 1233334”这个词。但我得到“男人,但是”这个词作为输出。任何人都可以帮我解决程序出了什么问题。
答案 0 :(得分:0)
决定最长单词的逻辑是错误的。
你正在比较一个“单词”(在这个上下文中,单词只是意味着用空格分隔的东西)和前一个单词,如果它更长,那么现在是最长的。
man,但之所以被选中,是因为它比前一个单词(短)长。请注意,人类之后没有任何内容,但之所以被选中,因为之后没有任何单词比之前的单词更长
答案 1 :(得分:0)
你做错了。如果secondLen
大于longestWord
,则不进行比较,实际上应该是:
longestWord = words[0];
for (int i = 1; i < words.length; i++) {
int longestLen = longestWord.length();
int secondLen = words[i].length();
if (longestLen <= secondLen) {
longestWord = words[i];
}
}
答案 2 :(得分:0)
您的方法找不到字符串数组中的最大字符串。它找到一个字符串数组中的最后一个字符串,它大于它之前的字符串。
您的比较(firstLen <= secondLen)
不会将任何字符串与当前最长的字符串进行比较。你的主循环应该是:
String longestWord = words[0];
for(String word : words) {
if(word.length() > longestWord.length()){
longestWord = word;
}
}
您也可以使用for(int i = 0; i < words.length(); i++)
并使用words[i]
代替(String word : words)
和word