https://www.acmicpc.net/problem/1924
1924번: 2007년
첫째 줄에 빈 칸을 사이에 두고 x(1 ≤ x ≤ 12)와 y(1 ≤ y ≤ 31)이 주어진다. 참고로 2007년에는 1, 3, 5, 7, 8, 10, 12월은 31일까지, 4, 6, 9, 11월은 30일까지, 2월은 28일까지 있다.
www.acmicpc.net
프로그래머스 문제 2016년 과 유사한 문제
2007년은 윤달이 아니며, 1/1일이 월요일로 시작 하는 것이 포인트
string에 월요일부터 차례대로 모두 넣어줌
x월이 1월 이상인 경우에 그 월의 요일을 모두 더해주고, 입력된 y일의 일수를 모두 더해서 7로 나눔
string에 한 번에 요일을 넣었기 때문에 일수의 합 %7 *3을 해주며 3칸씩해서 (요일) 답을 출력
#include <bits/stdc++.h>
using namespace std;
int main(void){
int x,y;
cin>>x>>y;
int day[12] = { 31,28,31,30,31,30,31,31,30,31,30,31};
string s = "MONTUEWEDTHUFRISATSUN";
int sum = 0;
if(x>1){
for(int i =0; i<x-1; i++){
sum+=day[i];
}
}
sum+= (y-1);
string answer =s.substr(sum%7*3,3);
cout<<answer<<"\n";
}
날짜 계산 로직,, 부시기 ,,,성공,,?
'Algorithm > BOJ' 카테고리의 다른 글
[c++] 백준 10972 -10974 다음/이전/모든 순열 (0) | 2021.02.25 |
---|---|
[c++] 백준 3671 산업 스파이의 편지 (2) | 2021.02.15 |
[c++] 백준 3085 사탕게임 (0) | 2021.02.01 |
[c++] 백준 2309 일곱 난쟁이 (0) | 2021.02.01 |
[c++] 백준 2231 분해합 (2) | 2021.01.28 |