栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Leetcode--Java--937. 重新排列日志文件

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Leetcode--Java--937. 重新排列日志文件

题目描述

样例描述
示例 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"]
思路

简单模拟 + 字符串处理

  1. 分别用两个list来存放字母和数字的字符串, 根据单个log的最后一位是字母还是数字来区分(因为首尾是标识符无法区分)
  2. 划分开后,对字母的list进行自定义排序,截取出内容(就是第一个’ '到末尾的部分 ),如果内容相同的话,就比较标识符,这里不需要再截取出标识符,因为后面的内容一样可以直接比较整个了。 如果内容不相同那就按内容的比较
  3. 字符串比较函数可以直接用compareTo,然后indexOf快速找到第一个’ '的位置
  4. 最后把数字log直接添加到字符log后面即可,因为不需要排序,保持相对距离就行
  5. list转array的方法,toArray(new 类型[]{})
代码
class Solution {
    public String[] reorderLogFiles(String[] logs) {
        List letters = new ArrayList<>();
        List 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[]{});
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/858123.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号