复建的第一题

理解题意

读懂题目就是一个活,所以我们用观察输出法,可以看出来月份,以及时间和费用之间的关系。

定义过程

然后时间要用什么来记录呢?day hour minute 好麻烦呀。。用字符串吧也可以比较大小的

看到这种结果分组的(就像是数据库里面group by之后的结果)就想到用map<string,xxx>

在这道题里面,xxx就是个容器里面存放了打电话挂电话的时间戳,

这个时间戳应该是用结构体的定义,首先需要是电话或者挂电话的时间点,还有这个时间点转化为的数字,以及状态。

题意延展

下一个难点就是计算费用,这里是参考别人的,利用打表的方式,把每分钟的费用给计算出来,这样再根据时间戳就可以减出整个对话长度的话费。

具体操作

剩下的就简单了,就是录入数据排下去,然后按每个人头(name)处理一下。<name,vector<record>>     first second

这里遍历就是auto,vector<record>一层的遍历是要两个两个遍历(这里是这个题的特色,因为他要求人在同一个时间段不可能有两个通话,所以以排序为主,出现的两个相邻而且是一个on一个end的就是我们要的区间,合法的区间)

输出要求

根据输出,我们可以看到,当这个人开始第1次输出的时候,要输出他的名字以及月份,后面要跟上话费以及最后要输出总话费,所以我可以通过话费来判断是否是输出名字还是输出时间条目。

ac代码

 1 #include<bits/stdc++.h>
2 using namespace std;
3 const int N=1000,M=24*60,minuteOfAMonth=31*M+10;
4 struct record{
5 int minute;
6 string formatTime;
7 string state;
8 };
9 bool cmp(record a,record b){
10 return a.minute<b.minute;
11 }
12 map<string,vector<record>> records;
13 double sum[minuteOfAMonth];
14 int money[25];
15 int main(){
16 int n;
17 for(int i=0;i<24;i++) cin>>money[i];
18 for(int i=1;i<minuteOfAMonth;i++)sum[i]=sum[i-1]+money[(i-1)%M/60]/100.0;
19 cin>>n;
20 int month,day,hour,minute;
21 char name[25],state[10],formatTime[25];
22 for(int i=0;i<n;i++){
23 scanf("%s %d:%d:%d:%d %s",name,&month,&day,&hour,&minute,state);
24 int minutes=(day-1)*M+60*hour+minute;
25 sprintf(formatTime,"%02d:%02d:%02d",day,hour,minute);
26 records[name].push_back({minutes,formatTime,state});
27 }
28 for(auto a:records){
29 double total=0;
30 string name=a.first;
31 auto person=a.second;
32 sort(person.begin(),person.end(),cmp);
33 for(int i=0;i+1<person.size();i++){
34 auto a=person[i],b=person[i+1];
35 if(a.state=="on-line"&&b.state=="off-line"){
36 if(!total){
37 printf("%s %02d\n",name.c_str(),month);
38 }
39 double charge=sum[b.minute]-sum[a.minute];
40 printf("%s %s %d $%.2lf\n",a.formatTime.c_str(),b.formatTime.c_str(),b.minute-a.minute,charge);
41 total+=charge;
42 }
43 }
44 if(total)printf("Total amount: $%.2lf\n",total);
45 }
46
47 }

新知

ps:sprintf真的灵性,学到了。可以这样构建字符串。

sprintf(a,"%02d",name);//name以%02d的格式输入到a中。

1016 Phone Bills (25分)的更多相关文章

  1. PAT 甲级 1016 Phone Bills (25 分) (结构体排序,模拟题,巧妙算时间,坑点太多,debug了好久)

    1016 Phone Bills (25 分)   A long-distance telephone company charges its customers by the following r ...

  2. 1016 Phone Bills (25 分)

    A long-distance telephone company charges its customers by the following rules: Making a long-distan ...

  3. 【PAT甲级】1016 Phone Bills (25 分)(结构体排序)

    题意: 输入24个正整数代表从0到23每个小时通话一分钟花费的美分.输入一个正整数N(<=1000),然后输入N组字符串,每个字符串包含客户的名字和通话的时刻以及打出或者挂断的状态. 按照字典序 ...

  4. 1016. Phone Bills (25)——PAT (Advanced Level) Practise

    题目信息: 1016. Phone Bills (25) 时间限制 400 ms 内存限制 32000 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue A l ...

  5. 1016. Phone Bills (25) -vector排序(sort函数)

    题目如下: A long-distance telephone company charges its customers by the following rules: Making a long- ...

  6. 1016 Phone Bills (25)(25 point(s))

    problem A long-distance telephone company charges its customers by the following rules: Making a lon ...

  7. A1016 Phone Bills (25 分)

    A long-distance telephone company charges its customers by the following rules: Making a long-distan ...

  8. PAT A 1016. Phone Bills (25)【模拟】

    题目:https://www.patest.cn/contests/pat-a-practise/1016 思路:用结构体存储,按照名字和日期排序,然后先判断是否有效,然后输出,时间加减直接暴力即可 ...

  9. 1016. Phone Bills (25)

    分析: 模拟题,提交无数次WA,注意几点: 1.如果某人没有有效通话记录,则不输出该人的信息,在此WA15次,题目看了N遍也没出现啊. 2.通话时间钱的计算:假设我们计算time1到time2的账单: ...

随机推荐

  1. 多元统计之因子分析模型及Python分析示例

    1. 简介 因子分析是一种研究观测变量变动的共同原因和特殊原因, 从而达到简化变量结构目的的多元统计方法. 因子分析模型是主成分分析的推广, 也是利用降维的思想, 将复杂的原始变量归结为少数几个综合因 ...

  2. python 字符串 增、删、改、查基本操作

    private static String TAG = "MainActivity"; private String str = " a,bB,1cCcc,2dDd d2 ...

  3. Docker以过时,看Containerd怎样一统天下

    Docker作为非常流行的容器技术,之前经常有文章说它被K8S弃用了,取而代之的是另一种容器技术containerd!其实containerd只是从Docker中分离出来的底层容器运行时,使用起来和D ...

  4. Selenium启动Firefox示例(java版)

    本文示例使用selenium启动Firefox,并将浏览器窗口最大化,在百度搜索框内输入"HelloWorld",最后点击搜索按钮. 源代码如下: 1 package com.se ...

  5. C语言:case详解

    C语言虽然没有限制 if else 能够处理的分支数量,但当分支过多时,用 if else 处理会不太方便,而且容易出现 if else 配对出错的情况.例如,输入一个整数,输出该整数对应的星期几的英 ...

  6. React事件绑定的方式

    一.是什么 在react应用中,事件名都是用小驼峰格式进行书写,例如onclick要改写成onClick 最简单的事件绑定如下: class ShowAlert extends React.Compo ...

  7. 一文读懂k8s rbac 权限验证

    自我认为的k8s三大难点:权限验证,覆盖网络,各种证书. 今天就说一下我所理解的权限验证rbac. 咱不说rbac0,rbac1,rbac2,rbac3.咱就说怎么控制权限就行. 一.前言 1,反正R ...

  8. ubuntu平台下,字符集的转换命令iconv

    iconv命令格式 iconv -f 源字符集(要转换文件的字符集) -t 目标字符集  file iconv -f gb18030 -t utf-8 file 默认情况下,不改变原文件,输出到屏幕. ...

  9. P2015

    二叉苹果树 1 #include<iostream> 2 #include<cstdio> 3 #include<algorithm> 4 #include< ...

  10. [考试总结]noip模拟7

    为啥博客园 \(\LaTeX\) 老挂???! \(\huge{\text{菜}}\) 刚开始写 \(T1\) 的时候,在看到后缀前缀之后,直接想到 \(AC\) 自动机,在画了半个 \(trie\) ...