1095 Cars on Campus (30 分)

一道排序问题,涉及到时间的处理和结构体数组的排序
坑点如下
1,结构体数组的排序,按照车牌号字母顺序排,如相同则按照时间来排,
比较函数如下

bool cmp(node a,node b){
    if(strcmp(a.id,b.id)!=0) return strcmp(a.id,b.id)<0;
    else return a.time<b.time;
}

2,通过对时间和状态从大到小排序后,根据状态判断前一个为in后一个为out的车辆,并将这一车辆记录。
3,测试点三一直无法通过,后来发现是query数组开小了,由题意开到80010后成功通过
整体代码如下

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<map>
using namespace std;
const int maxn=10010;
const int  maxk=80010;
struct node{
    char id[10];
    int time;
    char status[5];
}cars[maxn],valid[maxn];

bool cmp(node a,node b){
    if(strcmp(a.id,b.id)!=0) return strcmp(a.id,b.id)<0;
    else return a.time<b.time;
}

int query[maxk];
int main()
{
    int n,k;
    scanf("%d%d",&n,&k);
    int h,m,s;
    int timenow;
    for(int i=0;i<n;i++)
    {   
       scanf("%s %d:%d:%d %s",cars[i].id,&h,&m,&s,cars[i].status);
       timenow=h*3600+m*60+s;
       cars[i].time=timenow;
    }
  
    for(int i=0;i<k;i++)
    {
        scanf("%d:%d:%d",&h,&m,&s);
        timenow=h*3600+m*60+s;
        query[i]=timenow;
    }
    
    sort(cars,cars+n,cmp);
    map<string,int>mp;
    int num=0;
    int maxtime=-1;
    for(int i=0;i<n-1;i++){
       if(strcmp(cars[i].status,"in")==0&&strcmp(cars[i+1].status,"out")==0&&strcmp(cars[i+1].id,cars[i].id)==0)
          {     
              valid[num++].time=cars[i].time;
              valid[num++].time=cars[i+1].time;
              
              if(mp.count(cars[i].id)==0)
              {
                  mp[cars[i].id]=0;
              }
               mp[cars[i].id]+=cars[i+1].time-cars[i].time;
            maxtime=max(mp[cars[i].id],maxtime);
           
          }
    }
 
    
    for(int i=0;i<k;i++){
           int carsnow=0;
        for(int l=0;l<num;l+=2){
            if(valid[l].time<=query[i]&&valid[l+1].time>query[i])
             {   carsnow++;}
        }
          printf("%d\n",carsnow);
    }
    
    map<string,int>::iterator it;
    for(it=mp.begin();it!=mp.end();it++){
        if(it->second==maxtime)
        { printf("%s ",it->first.c_str());
 }
    }
    
    
    printf("%02d:%02d:%02d\n",maxtime/3600,maxtime%3600/60,maxtime%60);
    return 0;
    
    
    
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值