1016 Phone Bills
A long-distance telephone company charges its customers by the following rules:
Making a long-distance call costs a certain amount per minute, depending on the time of day when the call is made. When a customer starts connecting a long-distance call, the time will be recorded, and so will be the time when the customer hangs up the phone. Every calendar month, a bill is sent to the customer for each minute called (at a rate determined by the time of day). Your job is to prepare the bills for each month, given a set of phone call records.
Input Specification:
Each input file contains one test case. Each case has two parts: the rate structure, and the phone call records.
The rate structure consists of a line with 24 non-negative integers denoting the toll (cents/minute) from 00:00 - 01:00, the toll from 01:00 - 02:00, and so on for each hour in the day.
The next line contains a positive number N (≤), followed by N lines of records. Each phone call record consists of the name of the customer (string of up to 20 characters without space), the time and date (mm:dd:hh:mm), and the word on-line or off-line.
For each test case, all dates will be within a single month. Each on-line record is paired with the chronologically next record for the same customer provided it is an off-line record. Any on-line records that are not paired with an off-line record are ignored, as are off-line records not paired with an on-line record. It is guaranteed that at least one call is well paired in the input. You may assume that no two records for the same customer have the same time. Times are recorded using a 24-hour clock.
Output Specification:
For each test case, you must print a phone bill for each customer.
Bills must be printed in alphabetical order of customers' names. For each customer, first print in a line the name of the customer and the month of the bill in the format shown by the sample. Then for each time period of a call, print in one line the beginning and ending time and date (dd:hh:mm), the lasting time (in minute) and the charge of the call. The calls must be listed in chronological order. Finally, print the total charge for the month in the format shown by the sample.
Sample Input:
10 10 10 10 10 10 20 20 20 15 15 15 15 15 15 15 20 30 20 15 15 10 10 10
10
CYLL 01:01:06:01 on-line
CYLL 01:28:16:05 off-line
CYJJ 01:01:07:00 off-line
CYLL 01:01:08:03 off-line
CYJJ 01:01:05:59 on-line
aaa 01:01:01:03 on-line
aaa 01:02:00:01 on-line
CYLL 01:28:15:41 on-line
aaa 01:05:02:24 on-line
aaa 01:04:23:59 off-line
Sample Output:
CYJJ 01
01:05:59 01:07:00 61 $12.10
Total amount: $12.10
CYLL 01
01:06:01 01:08:03 122 $24.40
28:15:41 28:16:05 24 $3.85
Total amount: $28.25
aaa 01
02:00:01 04:23:59 4318 $638.80
Total amount: $638.80
题意:
计算每一个用户每一个月用在打电话上的开销。
思路:
模拟
Code:
1 #include <bits/stdc++.h>
2
3 using namespace std;
4
5 vector<int> costs(24);
6 int costOfDay;
7
8 struct People {
9 string name;
10 vector<string> on_line;
11 vector<string> off_line;
12 };
13
14 bool cmp1(People a, People b) { return a.name < b.name; }
15 bool cmp2(string s1, string s2) { return s1 < s2; }
16
17 pair<int, double> parse(string str1, string str2) {
18 int day1 = stoi(str1.substr(3, 2));
19 int day2 = stoi(str2.substr(3, 2));
20 pair<int, int> time1 = {stoi(str1.substr(6, 2)), stoi(str1.substr(9, 2))};
21 pair<int, int> time2 = {stoi(str2.substr(6, 2)), stoi(str2.substr(9, 2))};
22 int numOfDays = 0;
23 if (time1.first * 60 + time1.second < time2.first * 60 + time2.second) {
24 numOfDays = day2 - day1;
25 } else {
26 numOfDays = day2 - day1 - 1;
27 }
28 double cost = 0.0;
29 int totalMinute = 0;
30 if (time1.first == time2.first) {
31 cost += (time2.second - time1.second) * costs[time1.first];
32 totalMinute += time2.second - time1.second;
33 } else {
34 cost += (60 - time1.second) * costs[time1.first] +
35 time2.second * costs[time2.first];
36 totalMinute += 60 - time1.second + time2.second;
37 for (int i = time1.first + 1; i < time2.first; ++i) {
38 cost += 60 * costs[i];
39 totalMinute += 60;
40 }
41 }
42 totalMinute += numOfDays * 24 * 60;
43 cost += numOfDays * costOfDay;
44 double dollar = cost / 100.0;
45 return {totalMinute, dollar};
46 }
47
48 int main() {
49 for (int i = 0; i < 24; ++i) {
50 cin >> costs[i];
51 costOfDay += costs[i] * 60;
52 }
53 int N;
54 cin >> N;
55 getchar();
56 string record;
57 map<string, People> m;
58 for (int i = 0; i < N; ++i) {
59 getline(cin, record);
60 int space1, space2;
61 space1 = record.find(' ');
62 space2 = record.find(' ', space1 + 1);
63 string name = record.substr(0, space1);
64 string date = record.substr(space1 + 1, space2 - space1 - 1);
65 string status = record.substr(space2 + 1);
66 if (status == "on-line") {
67 m[name].on_line.push_back(date);
68 } else {
69 m[name].off_line.push_back(date);
70 }
71 }
72 vector<People> peoples;
73 for (auto it : m) {
74 it.second.name = it.first;
75 peoples.push_back(it.second);
76 }
77 sort(peoples.begin(), peoples.end(), cmp1);
78 for (People p : peoples) {
79 sort(p.on_line.begin(), p.on_line.end(), cmp2);
80 sort(p.off_line.begin(), p.off_line.end(), cmp2);
81 vector<string> start, end;
82 int index = 0, len1 = p.on_line.size(), len2 = p.off_line.size();
83 for (int i = 0; i < len2 && index < len1; ++i) {
84 while (index < len1 && p.on_line[index] < p.off_line[i]) index++;
85 if (index > 0) {
86 start.push_back(p.on_line[index - 1]);
87 end.push_back(p.off_line[i]);
88 }
89 }
90 cout << p.name << " " << start[0].substr(0, 2) << endl;
91 double totalCost = 0.0;
92 for (int i = 0; i < start.size(); ++i) {
93 cout << start[i].substr(3) << " " << end[i].substr(3) << " ";
94 pair<int, double> ans = parse(start[i], end[i]);
95 totalCost += ans.second;
96 cout << ans.first << " $" << fixed << setprecision(2) << ans.second
97 << endl;
98 }
99 cout << "Total amount: $" << totalCost << endl;
100 }
101
102 return 0;
103 }
写了好久,最后通过了一组测试点,溜了……(待我刷完PAT最后一题,再来补你)
1016 Phone Bills的更多相关文章
- PAT 1016 Phone Bills[转载]
1016 Phone Bills (25)(25 分)提问 A long-distance telephone company charges its customers by the followi ...
- 1016 Phone Bills (25 分)
1016 Phone Bills (25 分) A long-distance telephone company charges its customers by the following rul ...
- PAT甲级1016. Phone Bills
PAT甲级1016. Phone Bills 题意: 长途电话公司按以下规定向客户收取费用: 长途电话费用每分钟一定数量,具体取决于通话时间.当客户开始连接长途电话时,将记录时间,并且客户挂断电话时也 ...
- PAT 1016 Phone Bills(模拟)
1016. Phone Bills (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue A long-di ...
- 1016. Phone Bills (25)——PAT (Advanced Level) Practise
题目信息: 1016. Phone Bills (25) 时间限制 400 ms 内存限制 32000 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue A l ...
- PAT 甲级 1016 Phone Bills (25 分) (结构体排序,模拟题,巧妙算时间,坑点太多,debug了好久)
1016 Phone Bills (25 分) A long-distance telephone company charges its customers by the following r ...
- PAT A 1016. Phone Bills (25)【模拟】
题目:https://www.patest.cn/contests/pat-a-practise/1016 思路:用结构体存储,按照名字和日期排序,然后先判断是否有效,然后输出,时间加减直接暴力即可 ...
- PAT 1016. Phone Bills
A long-distance telephone company charges its customers by the following rules: Making a long-distan ...
- 1016. Phone Bills (25) -vector排序(sort函数)
题目如下: A long-distance telephone company charges its customers by the following rules: Making a long- ...
- 1016 Phone Bills (25)(25 point(s))
problem A long-distance telephone company charges its customers by the following rules: Making a lon ...
随机推荐
- Django模型层2
目录 一.聚合查询 聚合函数 二.分组查询 利用group by进行分组查询 三.F与Q查询 1. F类 2. Q类 四.orm字段及参数 五.自定义char字段 六.orm中的事务操作 1. 什么是 ...
- linux之docker 安装 mysql
首先进入docker : 命令:systemctl start docker 查詢一下docker的状态: 命令:docker images 现在开始安装mysql了,第一步拉取镜像 命令:doc ...
- .net 开源模板引擎jntemplate 实战演习:基础篇之入门
一.简介 模板引擎是Web开发中非常重要的一环,它负责将页面上的动态内容呈现出最终的结果展现给前端用户,在asp.net mvc中,我们最熟悉的就是Razor了,作为官方的视图引擎(视图引擎不等同于模 ...
- 番外----python入门----pip相关
pip 是 Python 包管理工具,该工具提供了对Python 包的查找.下载.安装.卸载的功能. 但是,由于pip使用的pip仓库默认为:http://pypi.python.org/ 是国外的 ...
- C# 基础 - 堆栈跟踪使用
使用一:可用于捕获报错时. using System.Diagnostics; ... StackTrace st = new StackTrace(true); string stackIndent ...
- C# 基础 - 委托、事件
1. 委托 sequenceDiagram 方法->>委托: 返回值和入参一样 委托->>方法: 调用委托就是调用绑定的方法 delegate int NumTest(int ...
- redhat配置问题
redhat开机自动连接网络配置 vim /etc/sysconfig/network-scripts/ifcfg-eth0 将 ONBOOT=no 更改为 yes 即可 redhat配置 yum ...
- 【Azure 微服务】PowerShell中,用Connect-ServiceFabricCluster命令无法连接到sf-test.chinaeast2.cloudapp.chinacloudapi.cn:19000 问题分析
问题描述 Azure Service Fabric提供了PowerShell的指令来进行创建,管理资源,如Get-ServiceFabricClusterHealth 获取当前集群的健康状态,但这些命 ...
- ElementUI Tree控件在懒加载模式下的重新加载和模糊查询
之所以使用懒加载是为了提高性能,而且只有在懒加载模式下默认会给所有显示节点设置展开按钮.leaf也可以做到,但是要操作数据比较麻烦. 要实现懒加载模式下的模糊查询以及重新加载必须要使用data与laz ...
- python-3-3 字典
一 元组(tuple) 1.元组也是一个list,他和list的区别是 元组里面的数据无法修改 元祖用()小括号表示,如果元祖里面只有一个元素的话,必须在这个元素的后面添加一个逗号,不然就不是元祖了 ...