프로그래머스/2레벨
주차 요금 계산/C++
Koalitsiya
2023. 1. 20. 14:22
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
풀이 방법
문자열을 시간 / 차량 번호 / 내역으로 잘라서 차량번호를 Key 해당 차량 번호의 시간들을 Value로 해서 map 컨테이너에 저장한다. 만약 value의 개수가 홀수라면 그 차량이 나간 기록이 records에 담겨 있지 않으므로 23:59에 출차한 것이니 value에 "23:59"를 추가한다. 이후 차량이 하루동안 몇 분 주차되어 있는지를 계산해서 기본 시간보다 짧으면 기본 요금을 아니라면 기본 요금에 단위 시간마다 단위 요금을 추가해서 answer에 담는다.
#include <string>
#include <vector>
#include <map>
#include <cmath>
using namespace std;
int convert_min(string s) {
int total_min = 0;
int hour = stoi(s.substr(0, 2));
int min = stoi(s.substr(3, 2));
total_min = hour * 60 + min;
return total_min;
}
vector<int> solution(vector<int> fees, vector<string> records) {
vector<int> answer;
map<string, vector<string>> m;
for(int i = 0; i < records.size(); i++) {
vector<string> v;
string tmp = "";
for(int j = 0; j < records[i].length(); j++) {
if(records[i][j] == ' ') {
v.push_back(tmp);
tmp = "";
}
else tmp += records[i][j];
}
v.push_back(tmp);
m[v[1]].push_back(v[0]);
v.clear();
}
for(auto it : m) {
vector<string> times = it.second;
if(times.size() % 2) times.push_back("23:59");
int time = 0;
for(int i = 0; i < times.size() - 1; i += 2) {
int num1 = convert_min(times[i]);
int num2 = convert_min(times[i+1]);
time += num2 - num1;
}
if(time > fees[0])
answer.push_back(fees[1] + ceil((time - fees[0]) / (double)fees[2]) * fees[3]);
else answer.push_back(fees[1]);
}
return answer;
}