博客
关于我
7-8 英文单词排序 (25 分)
阅读量:625 次
发布时间:2019-03-12

本文共 2017 字,大约阅读时间需要 6 分钟。

为了完成这个任务,我们需要编写一个Java程序,该程序可以从标准输入中读取英文单词,并将它们按长度排序。如果两个单词的长度相同,则按它们的出现顺序输出。这个任务可以通过使用Java的小程序框架来实现。

步骤一:读取输入

我们从标准输入读取数据,直到遇到标志性字符'#'。在读取过程中,我们将每个单词存储在一个字符串列表中。

import java.util.ArrayList;import java.util.Comparator;import java.util.Scanner;public class Main {    public static void main(String[] args) {        Scanner scanner = new Scanner(System.in);        ArrayList
words = new ArrayList<>(); while (scanner.hasNext("#")) { String word = scanner.next(); words.add(word); }

步骤二:自定义排序逻辑

我们需要按照单词的长度进行排序。如果两个单词的长度相同,则保持它们在输入时的相对顺序。为此,我们可以定义一个自定义的比较器。

words.sort((w1, w2) -> {    int len1 = w1.length();    int len2 = w2.length();        // 如果一个单词的长度小于另一个,放在前面    if (len1 != len2) {        return Integer.compare(len1, len2);    }        // 如果长度相同,按出现顺序排列    return words.indexOf(w1) - words.indexOf(w2);});

步骤三:输出结果

排序完成后,我们将结果依次输出到标准输出,每个单词后面跟一个空格。

for (String word : words) {    System.out.println(word + " ");}

步骤四:完整的代码

综上所述,完整的Java程序如下:

import java.util.ArrayList;import java.util.Comparator;import java.util.Scanner;public class Main {    public static void main(String[] args) {        Scanner scanner = new Scanner(System.in);        ArrayList
words = new ArrayList<>(); while (scanner.hasNext("#")) { String word = scanner.next(); words.add(word); } // 自定义排序逻辑 words.sort((w1, w2) -> { int len1 = w1.length(); int len2 = w2.length(); // 先比较长度 if (len1 != len2) { return Integer.compare(len1, len2); } // 长度相同,按输入顺序排列 return words.indexOf(w1) - words.indexOf(w2); }); // 输出排序后的结果 for (String word : words) { System.out.println(word + " "); } }}

Pedido de responsabilidade

Espero que este programa cumpra com os requisitos especificados. Caso haja algum erro ou necessidade de ajustes, por favor, informe-me.

转载地址:http://bmwaz.baihongyu.com/

你可能感兴趣的文章
MySQL集群解决方案(4):负载均衡
查看>>
MySQL高级-视图
查看>>
nacos集群搭建
查看>>
Nessus漏洞扫描教程之配置Nessus
查看>>
Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
查看>>
Netpas:不一样的SD-WAN+ 保障网络通讯品质
查看>>
Netty WebSocket客户端
查看>>
Netty工作笔记0011---Channel应用案例2
查看>>
Netty工作笔记0014---Buffer类型化和只读
查看>>
Netty工作笔记0050---Netty核心模块1
查看>>
Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
查看>>
Netty常见组件二
查看>>
netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
查看>>
Netty核心模块组件
查看>>
Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
查看>>
Netty源码—2.Reactor线程模型一
查看>>
Netty源码—4.客户端接入流程一
查看>>
Netty源码—4.客户端接入流程二
查看>>
Netty源码—5.Pipeline和Handler一
查看>>
Netty源码—6.ByteBuf原理二
查看>>