일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- SWEA
- 프로세스 상태
- 프로그래머스
- BOJ
- level3
- Modern C++
- binary search
- dirtyflag pattern
- PrefixSum
- two pointer
- Euclidean
- 8-Puzzle
- Silver
- Project
- Zenject
- Bronze
- knapsack Problem
- Gold
- programmers
- BFS
- Unity
- algorithm
- LEVEL2
- solid 원칙
- effective C++
- trie
- Flyweight Pattern
- 3D RPG
- stack
- level1
Archives
- Today
- Total
Patrick's Devlog
[BOJ/C++] 2007년(1924번) 본문
1. 문제 개요
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
1-1. 설명
오늘은 2007년 1월 1일 월요일이다. 그렇다면 2007년 x월 y일은 무슨요일일까? 이를 알아내는 프로그램을 작성하시오
1-2. 제한사항
- x월 y일을 입력받음
- x는 1이상 12이하, y는 1이상 31이하
- 2월은 28일까지 존재
2. 구현
2-1. 풀이
단순하게 요일과 달마다 일 수를 vector로 저장하고 x월 y일을 입력받아 일의 수를 합산하고 마지막에 7로 나눈 나머지를 구한다.
2-2. 코드
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector<string> week = { "SUN", "MON","TUE","WED","THU","FRI","SAT"};
vector<int> months = { 31,28,31,30,31,30,31,31,30,31,30,31 };
int month, day;
cin >> month >> day;
for (int i = 0; i < month-1; i++) day += months[i];
cout << week[day % 7] << endl;
}
'Algorithm > Algorithms Practice' 카테고리의 다른 글
[BOJ/C++] 소수(2581번) (0) | 2022.05.13 |
---|---|
[BOJ/C++] 스네이크버드(16435번) (0) | 2022.05.12 |
[프로그래머스/C++] 삼각 달팽이 (0) | 2022.05.06 |
[프로그래머스/C++] 최솟값 만들기 (0) | 2022.05.05 |
[프로그래머스/C++] 예산 (0) | 2022.05.02 |