코딩 테스트/프로그래머스
[프로그래머스] 개인정보 수집 유효기간
sangjin98
2024. 3. 14. 23:39
반응형
문제
https://school.programmers.co.kr/learn/courses/30/lessons/150370
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
문제 분석
[제한사항]
- today는 "YYYY.MM.DD" 형태로 오늘 날짜를 나타냅니다.
- 1 ≤ terms의 길이 ≤ 20
- terms의 원소는 "약관 종류 유효기간" 형태의 약관 종류와 유효기간을 공백 하나로 구분한 문자열입니다.
- 약관 종류는 A~Z중 알파벳 대문자 하나이며, terms 배열에서 약관 종류는 중복되지 않습니다.
- 유효기간은 개인정보를 보관할 수 있는 달 수를 나타내는 정수이며, 1 이상 100 이하입니다.
- 1 ≤ privacies의 길이 ≤ 100
- privacies[i]는 i+1번 개인정보의 수집 일자와 약관 종류를 나타냅니다.
- privacies의 원소는 "날짜 약관 종류" 형태의 날짜와 약관 종류를 공백 하나로 구분한 문자열입니다.
- 날짜는 "YYYY.MM.DD" 형태의 개인정보가 수집된 날짜를 나타내며, today 이전의 날짜만 주어집니다.
- privacies의 약관 종류는 항상 terms에 나타난 약관 종류만 주어집니다.
- today와 privacies에 등장하는 날짜의 YYYY는 연도, MM은 월, DD는 일을 나타내며 점(.) 하나로 구분되어 있습니다.
- 2000 ≤ YYYY ≤ 2022
- 1 ≤ MM ≤ 12
- MM이 한 자릿수인 경우 앞에 0이 붙습니다.
- 1 ≤ DD ≤ 28
- DD가 한 자릿수인 경우 앞에 0이 붙습니다.
- 파기해야 할 개인정보가 하나 이상 존재하는 입력만 주어집니다.
오늘 날짜 (today), 유효 기간 정보(terms), 개인정보 수집 일자 (privacies) 정보가 주어졌을 때
파기해야 할 개인정보를 찾아 반환해줘야 한다.
문제 접근
해당 문제는 문제에서 구현하라는 형식으로 그냥 구현하면 된다.
주어진 정보들을 잘 split 해서 날짜를 계산하고 오늘 날짜와 비교하여 파기해야 할 정보인지 고려하면 된다.
날짜 계산을 해야하기 때문에 날짜 계산 하는 것만 조심해서 계산한다면 문제를 해결할 수 있다.
코드
import java.util.*;
class Solution {
public int[] solution(String today, String[] terms, String[] privacies) {
List<Integer> answer = new ArrayList<>();
Map<String, Integer> map = new HashMap<>();
for (String term : terms) {
String type = term.split(" ")[0];
int month = Integer.parseInt(term.split(" ")[1]);
map.put(type, month);
}
int num = 1;
for (String privacy : privacies) {
// 수집 일자 -> year, month, day 로 split
String date = privacy.split(" ")[0];
String type = privacy.split(" ")[1];
String[] splitDate = date.split("\\.");
int year = Integer.parseInt(splitDate[0].trim());
int month = Integer.parseInt(splitDate[1].trim()) + map.get(type);
int day = Integer.parseInt(splitDate[2].trim());
year += month / 12;
month %= 12;
if (month == 0) {
month = 12;
year--;
}
today = today.replaceAll("\\.", "");
int dateInt = year * 10000 + month * 100 + day;
int todayInt = Integer.parseInt(today);
System.out.println(dateInt + " " + todayInt);
if (dateInt <= todayInt) {
answer.add(num);
}
num++;
}
return answer.stream().mapToInt(Integer::intValue).toArray();
}
}
반응형