Bootstrap

PAT-1009 说反话(java实现)

还是这种题好,多简单啊,题目多清晰明了啊,多让人增加学习的热情啊。

题目

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

输入格式:

测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。

输出格式:

每个测试用例的输出占一行,输出倒序后的句子。

输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello

解题思路

这道题解题思路都多余了,相信我的粉丝们也都是明眼人哈哈哈哈

  1. 拿到输入行英文句子。
    小技巧:scanner.nextLine()是获取一行的数据。(又多余了是吧哈哈)
  2. 把单词都存到有序(插入顺序)集合里,无顺的可不行哦。
    好,知识回顾 思考一下,都有哪些。文章最下边看答案哈
  3. 转为倒序然后输出,注意最后一个空格不能要哦,记得处理

代码

import java.util.*;

public class Main {
    public static void main(String args[]) {
        Scanner sc = new Scanner(System.in);
        String English = sc.nextLine();
        sc.close(); // 读取完输入后就可以关闭Scanner

        // 拆分单词并直接转换为列表
        List<String> wordList = new ArrayList<>(Arrays.asList(English.split(" ")));

        // 倒序列表
        Collections.reverse(wordList);

        // 使用StringBuilder拼接倒序的单词,每个单词后都加一个空格
        StringBuilder sb = new StringBuilder();
        for (String word : wordList) {
            sb.append(word).append(" ");
        }

        // 删除最后一个多余的空格
        sb.deleteCharAt(sb.length() - 1);

        // 打印结果
        System.out.println(sb);
    }
}

提交结果


Java🀄️

  1. 插入顺序有序的集合:

    • ArrayList: 一个基于数组实现的列表,它保持元素的插入顺序。
    • LinkedList: 一个基于链表实现的列表,它同样保持元素的插入顺序。
    • LinkedHashSet: 一个基于哈希表和链表实现的集合,它不仅保证元素唯一,也保持元素的插入顺序。
    • LinkedHashMap: 一个基于哈希表和链表实现的Map,它按照插入顺序来维护键值对。
  2. 排序顺序有序的集合:

    • TreeSet: 一个基于红黑树实现的集合,它保持元素的排序顺序。排序顺序可以是元素的自然排序顺序,或者根据构造时提供的Comparator来确定。
    • TreeMap: 一个基于红黑树实现的Map,它根据键的自然排序顺序或者构造时提供的Comparator来维护键值对的排序。
  3. 无序集合:

    "无序集合"指的是不保证元素顺序的集合。

    无论是插入顺序还是自然顺序,都不能得到保证。

    • HashSet: 基于哈希表实现,它不保证集合的迭代顺序;特别是,它不保证该顺序恒久不变。
    • HashMap: 基于哈希表的Map实现,不保证映射的顺序,特别是不保证该顺序恒久不变。

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;