본문 바로가기

prompt

[토요라운드] B. 기념일 1 (10420) [미완]

윤년때문에 어떻게 할까 엄청 고민하다가 날짜를 전부 일 수로 저장하고 더하는 방식으로 구하려 했다. 다시 년 / 월로 나눌 때는 년도별 일 수를 저장하고 거기에 맞게 나누는 방식으로.. 그런데 틀렸다. 어디서 틀렸는지는 살펴봐야 할듯

 

이건 틀린 코드

#include <iostream>
#include <algorithm>
#include <vector>
#include <string>
#include <functional>
#include <string>
#include <queue>
#include <stack>
#include <set>
#include <map>
#include <cmath>
#include <cstring>
#include <bitset>

#define xx first
#define yy second
#define all(x) (x).begin(), (x).end()

using namespace std;
using i64 = long long int;
using ii = pair<int, int>;
using ii64 = pair<i64, i64>;
using iii = tuple<int, int, int>;

int month[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31, 0};
int ymonth[] = { 0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31, 0};
int year[] = {0, 365, 366, 365, 365, 0};

int     main()
{
	int n;
	scanf("%d", &n);
	n--;

	for (int i = 1; i < 13; i++)
		month[i] = month[i] + month[i - 1];
	for (int i = 1; i < 13; i++)
		ymonth[i] = ymonth[i] + ymonth[i - 1];
	for (int i = 1; i < 5; i++)
		year[i] = year[i] + year[i - 1];

	int y = 0;
	int d = month[3] + 2 + n;
	int m = 0;

	//printf("%d %d %d\n", y, m, d);

	for (int i = 1; i < 5; i++)
	{
		if (d < year[i])
		{
			y = i - 1;
			d -= year[i - 1];
			break;
		}
	}

	//printf("%d %d %d\n", y, m, d);

	if (y != 2)
	{
		for (int i = 1; i < 13; i++)
		{
			if (d < month[i])
			{
				m = i - 1;
				d -= month[i - 1];
				break;
			}
		}
	}
	else
	{
		for (int i = 1; i < 13; i++)
		{
			if (d < ymonth[i])
			{
				m = i - 1;
				d -= ymonth[i - 1];
				break;
			}
		}
	}

	printf("%d-%d-%d\n", y + 2014, m + 1, d);

	
	return 0;
}

 

'prompt' 카테고리의 다른 글

[토요라운드] 20/12/05 후기  (0) 2020.12.07
[토요라운드] C. 사탕 (1812)  (0) 2020.11.07
[토요라운드] A. 쿠폰 (10179)  (0) 2020.11.07
[토요라운드] 20/11/07 후기  (0) 2020.11.07
[토요라운드] E. 풍선 공장 (15810)  (0) 2020.09.05