php小编草莓为你带来了一个有趣的字符串排序问题:对字符串长度排序,但相反。即最长的字符串排在最前面。这个问题可以通过使用内置函数和自定义排序函数来解决。在排序过程中,我们需要计算每个字符串的长度,并按照长度从大到小的顺序进行排序。接下来,我们将详细介绍如何实现这个有趣的字符串排序问题。
我必须做一个练习,我必须编写一个方法 orderquestionsbylength(),它应该按问题的长度(降序)对问题进行排序
以下代码有效(但未按降序排序):
`public void orderQuestionsByLength(){ Collections.sort(questions,Comparator.comparing(question -> question.getText().length())); for (Question question : questions){ System.out.println(question); } }`
一旦我添加.reversed(),我的ide就会抛出错误无法解析“对象”中的“gettext”方法即使我有一个方法gettext()并且它在添加.reversed之前就可以工作()
这让我发疯,因为我不知道如何解决这个问题,gpt说我的代码是正确的(并不是说我应该依赖gpt,但我有另一种方法,可以对整数进行降序排序,我使用了returned() 没有任何问题
有时会发生这种情况,因为 comparator.comparing 方法在与 .reversed() 链接时无法正确推断 lambda 参数的类型。
要解决此问题,您可以在 lambda 表达式中提供显式类型信息。以下是如何使用 (string question) -> …
修改 orderquestionsbylength
方法。
public void orderquestionsbylength() { collections.sort(questions, comparator.comparing((question question) -> question.gettext().length()).reversed()); for (question question : questions) { system.out.println(question); } }
调用 comparator#reversed
。
注意语法。 在使用 comparator.comparing
生成比较器后调用 reversed
。
comparator.comparing
是一个 static
方法调用,生成一个实例(对象)。comparator#reversed
是一个实例方法调用,生成另一个对象。正如chf的回答中指出的,您可能需要明确传递给的参数的数据类型lambda: ( 字符串问题 ) -> …
.
public void orderquestionsbylength() { collections.sort( questions, comparator .comparing( ( string question ) -> question.gettext().length() ) // static method call. .reversed() // instance method call. ); questions.foreach( system.out :: println ) ; }
顺便说一句,您可以使用 collections#foreach
和方法引用来折叠 for
循环,如上所示。
完整示例应用代码:
package work.basil.example; import java.util.ArrayList; import java.util.Comparator; import java.util.List; public class Infer { public static void main ( String[] args ) { Comparator < Question > comparator = Comparator .comparing ( ( Question question ) -> question.text ( ).length ( ) ) .reversed ( ); ArrayList < Question > questions = new ArrayList <> ( List.of ( new Question ( "alpha" , 1 ) , new Question ( "b" , 2 ) , new Question ( "gamma" , 3 ) ) ); questions.sort ( comparator ); questions.forEach ( System.out :: println ); } } record Question( String text , int points ) { }
以上是对字符串长度排序,但相反(最长的字符串在前)的详细内容。更多信息请关注PHP中文网其他相关文章!