字符串长度()比较无法正常工作

时间:2017-08-08 18:56:52

标签: java

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”这个词。但我得到“男人,但是”这个词作为输出。任何人都可以帮我解决程序出了什么问题。

3 个答案:

答案 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