[Programmers] Level1 : 개인정보 수집 유효기간
Question
Solution
- 약관 종류와 일수를 저장할 map을 선언한다.
- today와 privacies에 대해 년, 월, 일, 약관 종류를 모두 쪼개야 한다.
- today와 privacies를 일 수로 변환하고 유효기간을 고려하여 비교하면 된다.
Cord
#include <string>
#include <vector>
#include <algorithm>
#include <map>
using namespace std;
vector<int> solution(string today, vector<string> terms, vector<string> privacies)
{
vector<int> answer;
map<char, int> terms_map; // (약관 종류, 일 수)
const int month = 12;
const int day = 28;
// Key는 약관 종류, Value는 일 수로 map에 저장
for (int i = 0; i < terms.size(); ++i)
{
char alpha = terms[i][0];
string monthStr = terms[i].substr(2, terms[i].size());
int days = stoi(monthStr) * day;
terms_map.insert({ alpha, days });
}
// 오늘 날짜의 총 일 수 구하기
int today_year = stoi(today.substr(1, 3));
int today_month = stoi(today.substr(5, 6));
int today_day = stoi(today.substr(8, 9));
int today_total = (today_year * month * day) + ((today_month-1) * day) + today_day;
for (int i = 0; i < privacies.size(); ++i)
{
// 개인 정보 수집 일자의 총 일 수 구하기
int privacies_year = stoi(privacies[i].substr(1, 3));
int privacies_month = stoi(privacies[i].substr(5, 6));
int privacies_day = stoi(privacies[i].substr(8, 9));
int privacies_total = (privacies_year * month * day) + ((privacies_month-1) * day) + privacies_day;
char privacies_alpha = privacies[i][11];
int deadLine = privacies_total + terms_map[privacies_alpha];
// 기한이 안 남아있으면 유표기간 체크
if (today_total >= deadLine) { answer.push_back(i+1); }
}
return answer;
}