还是这种题好,多简单啊,题目多清晰明了啊,多让人增加学习的热情啊。
题目
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
解题思路
这道题解题思路都多余了,相信我的粉丝们也都是明眼人哈哈哈哈
- 拿到输入行英文句子。
小技巧:scanner.nextLine()是获取一行的数据。(又多余了是吧哈哈)- 把单词都存到有序(插入顺序)集合里,无顺的可不行哦。
好,知识回顾 思考一下,都有哪些。文章最下边看答案哈- 转为倒序然后输出,注意最后一个空格不能要哦,记得处理
代码
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🀄️
-
插入顺序有序的集合:
ArrayList
: 一个基于数组实现的列表,它保持元素的插入顺序。LinkedList
: 一个基于链表实现的列表,它同样保持元素的插入顺序。LinkedHashSet
: 一个基于哈希表和链表实现的集合,它不仅保证元素唯一,也保持元素的插入顺序。LinkedHashMap
: 一个基于哈希表和链表实现的Map,它按照插入顺序来维护键值对。
-
排序顺序有序的集合:
TreeSet
: 一个基于红黑树实现的集合,它保持元素的排序顺序。排序顺序可以是元素的自然排序顺序,或者根据构造时提供的Comparator
来确定。TreeMap
: 一个基于红黑树实现的Map,它根据键的自然排序顺序或者构造时提供的Comparator
来维护键值对的排序。
-
无序集合:
"无序集合"指的是不保证元素顺序的集合。
无论是插入顺序还是自然顺序,都不能得到保证。
HashSet
: 基于哈希表实现,它不保证集合的迭代顺序;特别是,它不保证该顺序恒久不变。HashMap
: 基于哈希表的Map
实现,不保证映射的顺序,特别是不保证该顺序恒久不变。