【九度】题目1130:日志排序

2024-08-25 12:38
文章标签 日志 题目 排序 九度 1130

本文主要是介绍【九度】题目1130:日志排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目地址:http://ac.jobdu.com/problem.php?pid=1130
题目描述:

有一个网络日志,记录了网络中计算任务的执行情况,每个计算任务对应一条如下形式的日志记录:
“hs_10000_p”是计算任务的名称,
“2007-01-17 19:22:53,315”是计算任务开始执行的时间“年-月-日 时:分:秒,毫秒”, 
“253.035(s)”是计算任务消耗的时间(以秒计)
hs_10000_p 2007-01-17 19:22:53,315 253.035(s)
请你写一个程序,对日志中记录计算任务进行排序。
时间消耗少的计算任务排在前面,时间消耗多的计算任务排在后面。
如果两个计算任务消耗的时间相同,则将开始执行时间早的计算任务排在前面。

输入:

日志中每个记录是一个字符串,每个字符串占一行。最后一行为空行,表示日志结束。日志中最多可能有10000条记录。
计算任务名称的长度不超过10,开始执行时间的格式是YYYY-MM-DD HH:MM:SS,MMM,消耗时间小数点后有三位数字。
计算任务名称与任务开始时间、消耗时间之间以一个或多个空格隔开,行首和行尾可能有多余的空格。

输出:

排序好的日志记录。每个记录的字符串各占一行。
输入的格式与输入保持一致,输入包括几个空格,你的输出中也应该包含同样多的空格。

样例输入:
hs_10000_p   2007-01-17 19:22:53,315     253.035(s)
hs_10001_p   2007-01-17 19:22:53,315     253.846(s)
hs_10002_m   2007-01-17 19:22:53,315     129.574(s)
hs_10002_p   2007-01-17 19:22:53,315     262.531(s)
hs_10003_m   2007-01-17 19:22:53,318     126.622(s)
hs_10003_p   2007-01-17 19:22:53,318     136.962(s)
hs_10005_m   2007-01-17 19:22:53,318     130.487(s)
hs_10005_p   2007-01-17 19:22:53,318     253.035(s)
hs_10006_m   2007-01-17 19:22:53,318     248.548(s)
hs_10006_p   2007-01-17 19:25:23,367    3146.827(s)
样例输出:
hs_10003_m   2007-01-17 19:22:53,318     126.622(s)
hs_10002_m   2007-01-17 19:22:53,315     129.574(s)
hs_10005_m   2007-01-17 19:22:53,318     130.487(s)
hs_10003_p   2007-01-17 19:22:53,318     136.962(s)
hs_10006_m   2007-01-17 19:22:53,318     248.548(s)
hs_10000_p   2007-01-17 19:22:53,315     253.035(s)
hs_10005_p   2007-01-17 19:22:53,318     253.035(s)
hs_10001_p   2007-01-17 19:22:53,315     253.846(s)
hs_10002_p   2007-01-17 19:22:53,315     262.531(s)
hs_10006_p   2007-01-17 19:25:23,367    3146.827(s)
来源:
2008年北京大学方正实验室计算机研究生机试真题
排序,难点在于时间比较大小。可以转为字符串比较。
C++ AC
#include <iostream>
#include<stdio.h>
#include<string.h>
#include<string>
#include<algorithm>
using namespace std;
const int maxn = 10002;
struct Task{char allMsg[200];char name[12];char startFir[15];char startSec[15];char wasteTime[15];
}tasks[maxn];bool cmp(Task t1,Task t2){int len1 = strlen(t1.wasteTime);int len2 = strlen(t2.wasteTime);if(len1 != len2){return len1 < len2;}else{int tmp = strcmp(t1.wasteTime , t2.wasteTime);if(tmp != 0){return tmp < 0;}else{tmp = strcmp(t1.startFir,t2.startFir);if(tmp != 0){return tmp < 0;}else{return strcmp(t1.startSec,t2.startSec) < 0;}}}
}
int main(){int k = 0;while(gets(tasks[k].allMsg)){sscanf(tasks[k].allMsg,"%s%s%s%s",tasks[k].name,tasks[k].startFir,tasks[k].startSec,tasks[k].wasteTime);k++;}sort(tasks,tasks + k,cmp);for(int i = 0; i < k; i++){cout<<tasks[i].allMsg<<endl;}   return 0;
}
/**************************************************************Problem: 1130User: wangzhenqingLanguage: C++Result: AcceptedTime:130 msMemory:4040 kb
****************************************************************/

Java AC

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.regex.Pattern;public class Main {/* * 1130 */  public static void main(String[] args) throws Exception {  BufferedReader br = new BufferedReader(new InputStreamReader( System.in ) )  ;           List<ComputerTask> comTaskList = new ArrayList<ComputerTask>();  while (true) {  String recordTask = br.readLine();  if (recordTask == null || "".equals(recordTask)) {  break;  }  String newRecordTask = recordTask.trim().replaceAll("['  ']+", " ");  String []array = newRecordTask.split(Pattern.quote(" "));   ComputerTask computerTask = new ComputerTask(array[0],   (array[1]+" "+array[2]),array[3],recordTask);  comTaskList.add(computerTask);  }  int size = comTaskList.size();  Collections.sort(comTaskList);  StringBuffer sb = new StringBuffer();  for (int i = 0; i < size; i++) {  sb.append(comTaskList.get(i).getAllMsg()+"\n");  }  System.out.print(sb.toString());  }      
}  
class ComputerTask implements Comparable<ComputerTask>{       private String taskId;  private String taskStartTime;  private String useTime;  private String allMsg;  public String getTaskId() {  return taskId;  }  public void setTaskId(String taskId) {  this.taskId = taskId;  }  public String getTaskStartTime() {  return taskStartTime;  }  public void setTaskStartTime(String taskStartTime) {  this.taskStartTime = taskStartTime;  }  public String getUseTime() {  return useTime;  }  public void setUseTime(String useTime) {  this.useTime = useTime;  }  public String getAllMsg() {  return allMsg;  }  public void setAllMsg(String allMsg) {  this.allMsg = allMsg;  }  public ComputerTask(String taskId, String taskStartTime, String useTime,  String allMsg) {  super();  this.taskId = taskId;  this.taskStartTime = taskStartTime;  this.useTime = useTime;  this.allMsg = allMsg;  }  public int compareTo(ComputerTask o) {  int len1 = this.getUseTime().length();int len2 = o.getUseTime().length();if (len1 != len2) {return len1 - len2;}else {int tmp = this.getUseTime().compareTo(o.getUseTime());if (tmp != 0) {return tmp;}else {len1 = this.getTaskStartTime().length();len2 = o.getTaskStartTime().length();if (len1 != len2) {return len1 - len2;}else {return this.getTaskStartTime().compareTo(o.getTaskStartTime());}}}}  
}/**************************************************************Problem: 1130User: wangzhenqingLanguage: JavaResult: AcceptedTime:1120 msMemory:101560 kb
****************************************************************/

这篇关于【九度】题目1130:日志排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1105576

相关文章

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

SpringBoot如何使用TraceId日志链路追踪

《SpringBoot如何使用TraceId日志链路追踪》文章介绍了如何使用TraceId进行日志链路追踪,通过在日志中添加TraceId关键字,可以将同一次业务调用链上的日志串起来,本文通过实例代码... 目录项目场景:实现步骤1、pom.XML 依赖2、整合logback,打印日志,logback-sp

Python中lambda排序的六种方法

《Python中lambda排序的六种方法》本文主要介绍了Python中使用lambda函数进行排序的六种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录1.对单个变量进行排序2. 对多个变量进行排序3. 降序排列4. 单独降序1.对单个变量进行排序

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

hdu 1285(拓扑排序)

题意: 给各个队间的胜负关系,让排名次,名词相同按从小到大排。 解析: 拓扑排序是应用于有向无回路图(Direct Acyclic Graph,简称DAG)上的一种排序方式,对一个有向无回路图进行拓扑排序后,所有的顶点形成一个序列,对所有边(u,v),满足u 在v 的前面。该序列说明了顶点表示的事件或状态发生的整体顺序。比较经典的是在工程活动上,某些工程完成后,另一些工程才能继续,此时

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

我在移动打工的日志

客户:给我搞一下录音 我:不会。不在服务范围。 客户:是不想吧 我:笑嘻嘻(气笑) 客户:小姑娘明明会,却欺负老人 我:笑嘻嘻 客户:那我交话费 我:手机号 客户:给我搞录音 我:不会。不懂。没搞过。 客户:那我交话费 我:手机号。这是电信的啊!!我这是中国移动!! 客户:我不管,我要充话费,充话费是你们的 我:可是这是移动!!中国移动!! 客户:我这是手机号 我:那又如何,这是移动!你是电信!!

题目1254:N皇后问题

题目1254:N皇后问题 时间限制:1 秒 内存限制:128 兆 特殊判题:否 题目描述: N皇后问题,即在N*N的方格棋盘内放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在同一斜线上。因为皇后可以直走,横走和斜走如下图)。 你的任务是,对于给定的N,求出有多少种合法的放置方法。输出N皇后问题所有不同的摆放情况个数。 输入