首页 > Java > 正文

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

王林
发布: 2024-02-13 23:57:08
转载
635人浏览过

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 方法。

快转字幕
快转字幕

新一代 AI 字幕工作站,为创作者提供字幕制作、学习资源、会议记录、字幕制作等场景,一键为您的视频生成精准的字幕。

快转字幕 357
查看详情 快转字幕
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中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:stackoverflow网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号