题目描述
样例描述
示例 1:
输入:logs = ["dig1 8 1 5 1","let1 art can","dig2 3 6","let2 own kit dig","let3 art zero"]
输出:["let1 art can","let3 art zero","let2 own kit dig","dig1 8 1 5 1","dig2 3 6"]
解释:
字母日志的内容都不同,所以顺序为 "art can", "art zero", "own kit dig" 。
数字日志保留原来的相对顺序 "dig1 8 1 5 1", "dig2 3 6" 。
示例 2:
输入:logs = ["a1 9 2 3 1","g1 act car","zo4 4 7","ab1 off key dog","a8 act zoo"]
输出:["g1 act car","a8 act zoo","ab1 off key dog","a1 9 2 3 1","zo4 4 7"]
思路
简单模拟 + 字符串处理
- 分别用两个list来存放字母和数字的字符串, 根据单个log的最后一位是字母还是数字来区分(因为首尾是标识符无法区分)
- 划分开后,对字母的list进行自定义排序,截取出内容(就是第一个’ '到末尾的部分 ),如果内容相同的话,就比较标识符,这里不需要再截取出标识符,因为后面的内容一样可以直接比较整个了。 如果内容不相同那就按内容的比较
- 字符串比较函数可以直接用compareTo,然后indexOf快速找到第一个’ '的位置
- 最后把数字log直接添加到字符log后面即可,因为不需要排序,保持相对距离就行
- list转array的方法,toArray(new 类型[]{})
代码
class Solution {
public String[] reorderLogFiles(String[] logs) {
List<String> letters = new ArrayList<>();
List<String> nums = new ArrayList<>();
for (String log: logs) {
char c = log.charAt(log.length() - 1);
if (Character.isDigit(c)) {
nums.add(log);
} else {
letters.add(log);
}
}
//对字母log自定义排序
Collections.sort(letters, (l1, l2) -> {
//截取出内容
String s1 = l1.substring(l1.indexOf(' ') + 1);
String s2 = l2.substring(l2.indexOf(' ') + 1);
//内容一样,比较标识符(也就是整个即可)
if (s1.equals(s2)) {
return l1.compareTo(l2);
} else {
return s1.compareTo(s2);
}
});
//数字追加到字母log后面
for (String s: nums) {
letters.add(s);
}
return letters.toArray(new String[]{});
}
}