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中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号