首页  >  文章  >  对字符串长度排序,但相反(最长的字符串在前)

对字符串长度排序,但相反(最长的字符串在前)

王林
王林转载
2024-02-13 23:57:08521浏览

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中文网其他相关文章!

声明:
本文转载于:stackoverflow.com。如有侵权,请联系admin@php.cn删除