博客
关于我
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/

你可能感兴趣的文章
Objective-C实现all combinations所有组合算法(附完整源码)
查看>>
Objective-C实现all permutations所有排列算法(附完整源码)
查看>>
Objective-C实现all subsequences所有子序列算法(附完整源码)
查看>>
Objective-C实现AlphaNumericalSort字母数字排序算法(附完整源码)
查看>>
Objective-C实现alternate disjoint set不相交集算法(附完整源码)
查看>>
Objective-C实现alternative list arrange备选列表排列算法(附完整源码)
查看>>
Objective-C实现An Armstrong number阿姆斯特朗数算法(附完整源码)
查看>>
Objective-C实现anagrams字谜算法(附完整源码)
查看>>
Objective-C实现ApproximationMonteCarlo蒙特卡洛方法计算pi值算法 (附完整源码)
查看>>
Objective-C实现area under curve曲线下面积算法(附完整源码)
查看>>
Objective-C实现argmax函数功能(附完整源码)
查看>>
Objective-C实现arithmetic算术算法(附完整源码)
查看>>
Objective-C实现armstrong numbers阿姆斯壮数算法(附完整源码)
查看>>
Objective-C实现articulation-points(关键点)(割点)算法(附完整源码)
查看>>
Objective-C实现atoi函数功能(附完整源码)
查看>>
Objective-C实现average absolute deviation平均绝对偏差算法(附完整源码)
查看>>
Objective-C实现average mean平均数算法(附完整源码)
查看>>
Objective-C实现average median平均中位数算法(附完整源码)
查看>>
Objective-C实现average mode平均模式算法(附完整源码)
查看>>
Objective-C实现avl 树算法(附完整源码)
查看>>