Submission #813454


Source Code Expand

#include <iomanip>
#include <iostream>
#include <iterator>
#include <list>
#include <string>
#include <tuple>
#include <utility>

using namespace std;

typedef tuple<int, int, int, int> ti;

bool debug = false;

int main(void){
	int n;
	cin >> n;
	list<ti> t;

	for (int i = 0; i < n; ++i)
	{
		int a, b, c, d;
		string s;
		cin >> s;
		//input format:
		//HHMM-HHMM
		//012345678
		//aabb ccdd
		a = stoi(s.substr(0, 2));
		b = stoi(s.substr(2, 2));
		c = stoi(s.substr(5, 2));
		d = stoi(s.substr(7, 2));
		if (d > 55) {
			++c;
		}
		b = (b/5)*5;
		d = (((d+4)/5)%12)*5;
		t.push_back(ti(a, b, c, d));
	}

	t.sort();

	if (debug)
	{
		for (list<ti>::iterator i = t.begin(); i != t.end(); ++i)
		{
			ti now = *i;
			cout << setfill('0') << right << setw(2) << get<0>(now) <<
			setw(2) << get<1>(now) << "-" << setw(2) << get<2>(now) <<
			setw(2) << get<3>(now) << endl;
		}
	}

	for (list<ti>::iterator i = t.begin(); i != --t.end(); ++i)
	{
		ti current = *i;
		++i;
		ti next = *i;
		--i;
		int endCH = get<2>(current);
		int endCM = get<3>(current);
		int startNH = get<0>(next);
		int startNM = get<1>(next);
		if (endCH > startNH || (endCH == startNH && endCM >= startNM))
		{
			ti merge;
			if (get<2>(next) > get<2>(current)) {
				merge = ti(get<0>(current), get<1>(current), get<2>(next), get<3>(next));
			} else if (get<2>(next) == get<2>(current)) {
				if (get<3>(next) > get<3>(current)) {
					merge = ti(get<0>(current), get<1>(current), get<2>(next), get<3>(next));
				} else {
					merge = ti(get<0>(current), get<1>(current), get<2>(current), get<3>(current));
				}
			} else {
				merge = ti(get<0>(current), get<1>(current), get<2>(current), get<3>(current));
			}
			i = t.insert(i, merge);
			++i;
			i = t.erase(i);
			i = t.erase(i);
			--i;
			--i;
		}
	}

	for (list<ti>::iterator i = t.begin(); i != t.end(); ++i)
	{
		ti now = *i;
		cout << setfill('0') << right << setw(2) << get<0>(now) <<
		setw(2) << get<1>(now) << "-" << setw(2) << get<2>(now) <<
		setw(2) << get<3>(now) << endl;
	}

	return 0;
}

Submission Info

Submission Time
Task D - 感雨時刻の整理
User L3Sota
Language C++11 (GCC 4.8.1)
Score 100
Code Size 2137 Byte
Status AC
Exec Time 99 ms
Memory 2464 KB

Judge Result

Set Name all
Score / Max Score 100 / 100
Status
AC × 48
Set Name Test Cases
all 00_sample_01.txt, 00_sample_02.txt, 00_sample_03.txt, cho_cho_chokudai.txt, chokudai_ga_cho.txt, test_01.txt, test_02.txt, test_03.txt, test_04.txt, test_05.txt, test_06.txt, test_07.txt, test_08.txt, test_09.txt, test_10.txt, test_11.txt, test_12.txt, test_13.txt, test_14.txt, test_15.txt, test_16.txt, test_17.txt, test_18.txt, test_19.txt, test_20.txt, test_21.txt, test_22.txt, test_23.txt, test_24.txt, test_25.txt, test_26.txt, test_27.txt, test_28.txt, test_29.txt, test_30.txt, test_31.txt, test_32.txt, test_33.txt, test_34.txt, test_35.txt, test_36.txt, test_37.txt, test_38.txt, test_39.txt, test_40.txt, test_41.txt, test_42.txt, test_43.txt
Case Name Status Exec Time Memory
00_sample_01.txt AC 30 ms 928 KB
00_sample_02.txt AC 28 ms 924 KB
00_sample_03.txt AC 28 ms 920 KB
cho_cho_chokudai.txt AC 89 ms 2232 KB
chokudai_ga_cho.txt AC 91 ms 2236 KB
test_01.txt AC 29 ms 856 KB
test_02.txt AC 30 ms 1056 KB
test_03.txt AC 31 ms 920 KB
test_04.txt AC 29 ms 924 KB
test_05.txt AC 30 ms 1052 KB
test_06.txt AC 33 ms 880 KB
test_07.txt AC 30 ms 1056 KB
test_08.txt AC 30 ms 928 KB
test_09.txt AC 30 ms 984 KB
test_10.txt AC 32 ms 956 KB
test_11.txt AC 40 ms 864 KB
test_12.txt AC 32 ms 1048 KB
test_13.txt AC 30 ms 1052 KB
test_14.txt AC 28 ms 1052 KB
test_15.txt AC 30 ms 956 KB
test_16.txt AC 31 ms 1052 KB
test_17.txt AC 31 ms 1056 KB
test_18.txt AC 29 ms 928 KB
test_19.txt AC 30 ms 1056 KB
test_20.txt AC 30 ms 1052 KB
test_21.txt AC 97 ms 2236 KB
test_22.txt AC 99 ms 2240 KB
test_23.txt AC 98 ms 2272 KB
test_24.txt AC 97 ms 2336 KB
test_25.txt AC 96 ms 2464 KB
test_26.txt AC 97 ms 2460 KB
test_27.txt AC 93 ms 2240 KB
test_28.txt AC 99 ms 2456 KB
test_29.txt AC 29 ms 1056 KB
test_30.txt AC 29 ms 864 KB
test_31.txt AC 38 ms 1184 KB
test_32.txt AC 31 ms 928 KB
test_33.txt AC 74 ms 1856 KB
test_34.txt AC 30 ms 1056 KB
test_35.txt AC 29 ms 1052 KB
test_36.txt AC 96 ms 2236 KB
test_37.txt AC 96 ms 2464 KB
test_38.txt AC 97 ms 2240 KB
test_39.txt AC 98 ms 2240 KB
test_40.txt AC 96 ms 2336 KB
test_41.txt AC 91 ms 2236 KB
test_42.txt AC 97 ms 2240 KB
test_43.txt AC 92 ms 2236 KB