这道题是LeetCode里的第937道题。

题目描述:

你有一个日志数组 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. 0 <= logs.length <= 100
  2. 3 <= logs[i].length <= 100
  3. logs[i] 保证有一个标识符,并且标识符后面有一个字。

题目的意思很简单,但是由于处理的是字符串,处理起来就会相对的麻烦一些。

首先我们先要用一个 List 结构来保存日志的文章开头下标,即除去标识符和一个空格,例如:日志 "a1 9 2 3 1" 我们保存它的下标为3,其它的日志也是相同的道理。保存后在转成一个 Object[] 数组,因为对 List 不是很熟练而且 List 不支持下标访问,所以使用了这个方法来简化后面的操作。然后就是排序了,我这里使用的排序方法类似于插入排序:就是抽取一本日志,然后在把这本日志合适的插入已经排好序的日志堆里。排序遍历的时候需要注意的几个问题:

  • 拿到的日志是那种日志
  • 日志插在哪个位置才合适
  • 要如何处理逻辑关系

解题代码:

class Solution {
public static String[] reorderLogFiles(String[] logs){
List<Integer>recodeIndex = new ArrayList<>(); for(String log : logs) {
for(int i = 0;i < log.length(); i++) {
if(log.charAt(i) == ' ') {
recodeIndex.add(i + 1);
break;
}
}
} Object[] recode = recodeIndex.toArray(); for(int i = 0; i < logs.length; i++) {//遍历logs
if(logs[i].charAt((int) recode[i])>='0'&&logs[i].charAt((int) recode[i])<='9')continue;
int insert = i;
int numCount = 0;
for(int j = 0; j < i; j++) {//遍历已排序好的logs
if(logs[j].charAt((int) recode[j])>='0'&&logs[j].charAt((int) recode[j])<='9')
{numCount++;continue;}//判断是否为数字日志 int len = logs[j].length();//另一本日志的长度
int sortIndex = (int) recode[j];//另一本日志的开头位置
for(int k = (int) recode[i]; k < logs[i].length(); k++) {//寻找插入位
if(len < k || logs[i].charAt(k) > logs[j].charAt(sortIndex)){break;}
else if(logs[i].charAt(k) == logs[j].charAt(sortIndex)) {sortIndex++;continue;}
else {insert = j;break;}
}
if(insert < i)break;
} int tempIndex = recodeIndex.get(i);
String temp = new String(logs[i]);
for(int l = i;l > insert - numCount; l--) {
logs[l] = logs[l - 1];
recode[l] = recode[l - 1];
}
logs[insert - numCount] = temp;//同时不要忘记交换对应的日志开头下标数组
recode[insert - numCount] = tempIndex;
} return logs;
}
}

解题结果:

过程感悟:

我在编写算法的过程中一部分时间浪费在忘记处理 recode 数组上了,调试后才发现问题,在一个就是交换的 for 循环的循环次数和上下界,当时由于代码的逻辑混乱造成了一些失误,现在的代码是我简化后的结果,当然可以再次简化。或许这道题可以使用哈希表或者队列来解决。

附记:lambda表达式

【LeetCode】Reorder Log Files(重新排列日志文件)的更多相关文章

  1. Leetcode937. Reorder Log Files重新排列日志文件

    你有一个日志数组 logs.每条日志都是以空格分隔的字串. 对于每条日志,其第一个字为字母数字标识符.然后,要么: 标识符后面的每个字将仅由小写字母组成,或: 标识符后面的每个字将仅由数字组成. 我们 ...

  2. 【Leetcode_easy】937. Reorder Log Files

    problem 937. Reorder Log Files solution: class Solution { public: vector<string> reorderLogFil ...

  3. Linux /var/log下的各种日志文件详解

    1)/var/log/secure:记录登录系统存取数据的文件;例如:pop3,ssh,telnet,ftp等都会记录在此. 2)/var/log/wtmp:记录登录这的信息记录,被编码过,所以必须以 ...

  4. java最简单实现Log打印和生成日志文件

    导包 1.commons-logging.jar包 下载 2.log4j.jar包 下载 配置log4j 1.在src根目录下创建一个log4j.properties文件. 文件全部内容如下: log ...

  5. [Swift]LeetCode937. 重新排列日志文件 | Reorder Log Files

    You have an array of logs.  Each log is a space delimited string of words. For each log, the first w ...

  6. LeetCode.937-重新排序日志数组(Reorder Log Files)

    这是悦乐书的第358次更新,第385篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第220题(顺位题号是937).你有一系列日志.每个日志都是以空格分隔的单词串. 每个日 ...

  7. 【LeetCode】937. Reorder Log Files 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 分割和排序 日期 题目地址:https://leet ...

  8. LeetCode 937 Reorder Log Files 解题报告

    题目要求 You have an array of logs.  Each log is a space delimited string of words. For each log, the fi ...

  9. 【leetcode】937. Reorder Log Files

    题目如下: You have an array of logs.  Each log is a space delimited string of words. For each log, the f ...

随机推荐

  1. java 利用c3p0管理数据库连接池

    数据库连接池类,用于获取数据库连接.利用单例模式保证所有的连接都只通过一个连接池管理. package com.mousewheel.dbcon; import java.io.InputStream ...

  2. 用java自带jdk开发第一个java程序

    [学习笔记] 1.用java自带jdk开发第一个java程序:   下面要讲的eclipse要想正常工作,需要先学会配置这里的jdk.jdk要想正常工作,需先学会配置JAVA_HOME和ClassPa ...

  3. arcgis jsapi接口入门系列(8):鼠标在地图画面

    初始化,每个map执行一次 PS:画点也差不多,都是用SketchViewModel,因此本demo没有专门写画点的 drawPolygonInit: function () { //画几何对象初始化 ...

  4. Jordan 标准型定理

    将学习到什么 就算两个矩阵有相同的特征多项式,它们也有可能不相似,那么如何判断两个矩阵是相似的?答案是它们有一样的 Jordan 标准型.   Jordan 标准型定理 这节目的:证明每个复矩阵都与一 ...

  5. WINDOWS-API:取得当前用户账户名-GetUserName

    bool TFormMain::GetCurrentProcessUser(AnsiString& strUserName) { bool bRet = false; //strUserNam ...

  6. [Tkinter 教程] 布局管理 (Pack Place Grid)

    原系列地址: Python Tkinter 简介: 本文讲述如何使用 tkinter 的布局管理 (被称作 layout managers 或 geometry managers). tkinter ...

  7. Bootstrap响应式布局(1)

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

  8. Paxos算法与Zookeeper分析,zab (zk)raft协议(etcd) 8. 与Galera及MySQL Group replication的比较

    mit 分布式论文集 https://github.com/feixiao/Distributed-Systems wiki上描述的几种都明白了就出师了 raft 和 zab 是类似的,都是1.先选举 ...

  9. 四. python网络编程

    第八章.网络基础知识 1. TCP/IP协议介绍 1.TCP/IP概念 TCP/IP: Transmission Control Protocol/Internet Protocol的简写,中译名为传 ...

  10. ios UITableViewCell重用问题

    在写sina 微博界面的过程中使用到了cell,那么就是在cell上添加一些控件,但是由于每条微博的内容都是不同的,所以在显示的过程中,出现了内容重叠的问题,其实就是UITableViewCell重用 ...