Submission #3776659


Source Code Expand

#include <bits/stdc++.h>

using namespace std;

unordered_map <int,int> box;

int main(void)
{
	cin.tie(0);
	ios::sync_with_stdio(false);

	// r g b 0 1 2
	int r,g,b;
	int res = 0;
	int idx1 = -100,idx2 = 0,idx3 = 100;

	cin >> r >> g >> b;

	box[idx1] = 0;
	r-=1;
	box[idx2] = 1;
	g-=1;
	box[idx3] = 2;
	b-=1;

	if(r<b)
	{
		int left = -1;
		int right = 1;
		bool turn = true;
		while(g>0)
		{
			if(turn)
			{
				while(1)
				{
					if(box.find(left)==box.end())
					{
						break;
					}
					left--;
				}
				box[left] = 1;
				g--;
				//cout << abs(left) << '\n';
				res += abs(left);
				turn = false;
			}
			else
			{
				while(1)
				{
					if(box.find(right)==box.end())
					{
						break;
					}
					right++;
				}
				box[right] = 1;
				g--;
				//cout << abs(right) << '\n';
				res += abs(right);
				turn = true;
			}
		}	
	}
	else
	{
		int left = -1;
		int right = 1;
		bool turn = false;
		while(g>0)
		{
			if(turn)
			{
				while(1)
				{
					if(box.find(left)==box.end())
					{
						break;
					}
					left--;
				}
				box[left] = 1;
				g--;
				//cout << abs(left) << '\n';
				res += abs(left);
				turn = false;
			}
			else
			{
				while(1)
				{
					if(box.find(right)==box.end())
					{
						break;
					}
					right++;
				}
				box[right] = 1;
				g--;
				//cout << abs(right) << '\n';
				res += abs(right);
				turn = true;
			}
		}	
	}

	// r

	bool flag = false;
	if(box.find(-99)!=box.end())
	{
		flag = true;
	}

	if(flag)
	{
		int left = -101;
		while(r>0)
		{
			while(1)
			{
				if(box.find(left)==box.end())
				{
					break;
				}
				left--;
			}
			box[left] = 0;
			r--;
			//cout << abs(-100 - left);
			res += abs(-100 - left);
		}
	}
	else
	{
		int left = -101;
		int right = -99;
		bool isused = true;
		bool turn = true;
		while(r>0)
		{
			if(isused)
			{
				if(turn==true)
				{
					while(1)
					{
						if(box.find(left)==box.end())
						{
							break;
						}
						left--;
					}
					box[left] = 0;
					r--;
					res += abs(-100 - left);
					turn = false;
				}
				else
				{
					if(box[right]==1)
					{
						isused=false;
					}
					else
					{
						box[right] = 0;
						r--;
						res += abs(-100 - right);
						turn = true;
						right++;
					}
				}

			}
			else
			{
				while(1)
				{
					if(box.find(left)==box.end())
					{
						break;
					}
					left--;
				}
				box[left] = 0;
				r--;
				res += abs(-100 -left);
			}
		}
	}

	flag = false;
	if(box.find(99)!=box.end())
	{
		flag = true;
	}

	if(flag)
	{
		int right = 101;
		while(b>0)
		{
			while(1)
			{
				if(box.find(right)==box.end())
				{
					break;
				}
				right++;
			}
			box[right] = 2;
			b--;
			res += abs(100 - right);
		}
	}
	else
	{
		int left = 99;
		int right = 101;
		bool isused = true;
		bool turn = true;
		while(b>0)
		{
			if(isused)
			{
				if(turn==true)
				{
					while(1)
					{
						if(box.find(right)==box.end())
						{
							break;
						}
						right++;
					}
					box[right] = 2;
					b--;
					res += abs(100 - right);
					turn = false;
				}
				else
				{
					if(box[left]==1)
					{
						isused=false;
					}
					else
					{
						box[left] = 2;
						b--;
						res += abs(100 - left);
						turn = true;
						left--;
					}
				}

			}
			else
			{
				while(1)
				{
					if(box.find(right)==box.end())
					{
						break;
					}
					right++;
				}
				box[right] = 2;
				b--;
				res += abs(100 - right);
			}
		}		
	}

	cout << res << '\n';

	return 0;
}

Submission Info

Submission Time
Task D - マーブル
User joker_x
Language C++14 (GCC 5.4.1)
Score 40
Code Size 3751 Byte
Status WA
Exec Time 1 ms
Memory 256 KB

Judge Result

Set Name sub1 sub2 All
Score / Max Score 10 / 10 30 / 30 0 / 60
Status
AC × 29
AC × 57
AC × 62
WA × 23
Set Name Test Cases
sub1 sample_01_ABC.txt, test_ABC_01.txt, test_ABC_02.txt, test_ABC_03.txt, test_ABC_04.txt, test_ABC_05.txt, test_ABC_06.txt, test_ABC_07.txt, test_ABC_08.txt, test_ABC_09.txt, test_ABC_10.txt, test_ABC_11.txt, test_ABC_12.txt, test_ABC_13.txt, test_ABC_14.txt, test_ABC_15.txt, test_ABC_16.txt, test_ABC_17.txt, test_ABC_18.txt, test_ABC_19.txt, test_ABC_20.txt, test_ABC_21.txt, test_ABC_22.txt, test_ABC_23.txt, test_ABC_24.txt, test_ABC_25.txt, test_ABC_26.txt, test_ABC_27.txt, test_ABC_28.txt
sub2 sample_01_ABC.txt, sample_02_BC.txt, test_ABC_01.txt, test_ABC_02.txt, test_ABC_03.txt, test_ABC_04.txt, test_ABC_05.txt, test_ABC_06.txt, test_ABC_07.txt, test_ABC_08.txt, test_ABC_09.txt, test_ABC_10.txt, test_ABC_11.txt, test_ABC_12.txt, test_ABC_13.txt, test_ABC_14.txt, test_ABC_15.txt, test_ABC_16.txt, test_ABC_17.txt, test_ABC_18.txt, test_ABC_19.txt, test_ABC_20.txt, test_ABC_21.txt, test_ABC_22.txt, test_ABC_23.txt, test_ABC_24.txt, test_ABC_25.txt, test_ABC_26.txt, test_ABC_27.txt, test_ABC_28.txt, test_BC_29.txt, test_BC_30.txt, test_BC_31.txt, test_BC_32.txt, test_BC_33.txt, test_BC_34.txt, test_BC_35.txt, test_BC_36.txt, test_BC_37.txt, test_BC_38.txt, test_BC_39.txt, test_BC_40.txt, test_BC_41.txt, test_BC_42.txt, test_BC_43.txt, test_BC_44.txt, test_BC_45.txt, test_BC_46.txt, test_BC_47.txt, test_BC_48.txt, test_BC_49.txt, test_BC_50.txt, test_BC_51.txt, test_BC_52.txt, test_BC_53.txt, test_BC_54.txt, test_BC_55.txt
All sample_01_ABC.txt, sample_02_BC.txt, sample_03_C.txt, test_ABC_01.txt, test_ABC_02.txt, test_ABC_03.txt, test_ABC_04.txt, test_ABC_05.txt, test_ABC_06.txt, test_ABC_07.txt, test_ABC_08.txt, test_ABC_09.txt, test_ABC_10.txt, test_ABC_11.txt, test_ABC_12.txt, test_ABC_13.txt, test_ABC_14.txt, test_ABC_15.txt, test_ABC_16.txt, test_ABC_17.txt, test_ABC_18.txt, test_ABC_19.txt, test_ABC_20.txt, test_ABC_21.txt, test_ABC_22.txt, test_ABC_23.txt, test_ABC_24.txt, test_ABC_25.txt, test_ABC_26.txt, test_ABC_27.txt, test_ABC_28.txt, test_BC_29.txt, test_BC_30.txt, test_BC_31.txt, test_BC_32.txt, test_BC_33.txt, test_BC_34.txt, test_BC_35.txt, test_BC_36.txt, test_BC_37.txt, test_BC_38.txt, test_BC_39.txt, test_BC_40.txt, test_BC_41.txt, test_BC_42.txt, test_BC_43.txt, test_BC_44.txt, test_BC_45.txt, test_BC_46.txt, test_BC_47.txt, test_BC_48.txt, test_BC_49.txt, test_BC_50.txt, test_BC_51.txt, test_BC_52.txt, test_BC_53.txt, test_BC_54.txt, test_BC_55.txt, test_C_56.txt, test_C_57.txt, test_C_58.txt, test_C_59.txt, test_C_60.txt, test_C_61.txt, test_C_62.txt, test_C_63.txt, test_C_64.txt, test_C_65.txt, test_C_66.txt, test_C_67.txt, test_C_68.txt, test_C_69.txt, test_C_70.txt, test_C_71.txt, test_C_72.txt, test_C_73.txt, test_C_74.txt, test_C_75.txt, test_C_76.txt, test_C_77.txt, test_C_78.txt, test_C_79.txt, test_C_80.txt, test_C_81.txt, test_C_82.txt
Case Name Status Exec Time Memory
sample_01_ABC.txt AC 1 ms 256 KB
sample_02_BC.txt AC 1 ms 256 KB
sample_03_C.txt WA 1 ms 256 KB
test_ABC_01.txt AC 1 ms 256 KB
test_ABC_02.txt AC 1 ms 256 KB
test_ABC_03.txt AC 1 ms 256 KB
test_ABC_04.txt AC 1 ms 256 KB
test_ABC_05.txt AC 1 ms 256 KB
test_ABC_06.txt AC 1 ms 256 KB
test_ABC_07.txt AC 1 ms 256 KB
test_ABC_08.txt AC 1 ms 256 KB
test_ABC_09.txt AC 1 ms 256 KB
test_ABC_10.txt AC 1 ms 256 KB
test_ABC_11.txt AC 1 ms 256 KB
test_ABC_12.txt AC 1 ms 256 KB
test_ABC_13.txt AC 1 ms 256 KB
test_ABC_14.txt AC 1 ms 256 KB
test_ABC_15.txt AC 1 ms 256 KB
test_ABC_16.txt AC 1 ms 256 KB
test_ABC_17.txt AC 1 ms 256 KB
test_ABC_18.txt AC 1 ms 256 KB
test_ABC_19.txt AC 1 ms 256 KB
test_ABC_20.txt AC 1 ms 256 KB
test_ABC_21.txt AC 1 ms 256 KB
test_ABC_22.txt AC 1 ms 256 KB
test_ABC_23.txt AC 1 ms 256 KB
test_ABC_24.txt AC 1 ms 256 KB
test_ABC_25.txt AC 1 ms 256 KB
test_ABC_26.txt AC 1 ms 256 KB
test_ABC_27.txt AC 1 ms 256 KB
test_ABC_28.txt AC 1 ms 256 KB
test_BC_29.txt AC 1 ms 256 KB
test_BC_30.txt AC 1 ms 256 KB
test_BC_31.txt AC 1 ms 256 KB
test_BC_32.txt AC 1 ms 256 KB
test_BC_33.txt AC 1 ms 256 KB
test_BC_34.txt AC 1 ms 256 KB
test_BC_35.txt AC 1 ms 256 KB
test_BC_36.txt AC 1 ms 256 KB
test_BC_37.txt AC 1 ms 256 KB
test_BC_38.txt AC 1 ms 256 KB
test_BC_39.txt AC 1 ms 256 KB
test_BC_40.txt AC 1 ms 256 KB
test_BC_41.txt AC 1 ms 256 KB
test_BC_42.txt AC 1 ms 256 KB
test_BC_43.txt AC 1 ms 256 KB
test_BC_44.txt AC 1 ms 256 KB
test_BC_45.txt AC 1 ms 256 KB
test_BC_46.txt AC 1 ms 256 KB
test_BC_47.txt AC 1 ms 256 KB
test_BC_48.txt AC 1 ms 256 KB
test_BC_49.txt AC 1 ms 256 KB
test_BC_50.txt AC 1 ms 256 KB
test_BC_51.txt AC 1 ms 256 KB
test_BC_52.txt AC 1 ms 256 KB
test_BC_53.txt AC 1 ms 256 KB
test_BC_54.txt AC 1 ms 256 KB
test_BC_55.txt AC 1 ms 256 KB
test_C_56.txt WA 1 ms 256 KB
test_C_57.txt WA 1 ms 256 KB
test_C_58.txt WA 1 ms 256 KB
test_C_59.txt WA 1 ms 256 KB
test_C_60.txt WA 1 ms 256 KB
test_C_61.txt WA 1 ms 256 KB
test_C_62.txt AC 1 ms 256 KB
test_C_63.txt WA 1 ms 256 KB
test_C_64.txt WA 1 ms 256 KB
test_C_65.txt WA 1 ms 256 KB
test_C_66.txt WA 1 ms 256 KB
test_C_67.txt WA 1 ms 256 KB
test_C_68.txt AC 1 ms 256 KB
test_C_69.txt WA 1 ms 256 KB
test_C_70.txt WA 1 ms 256 KB
test_C_71.txt WA 1 ms 256 KB
test_C_72.txt WA 1 ms 256 KB
test_C_73.txt WA 1 ms 256 KB
test_C_74.txt WA 1 ms 256 KB
test_C_75.txt WA 1 ms 256 KB
test_C_76.txt WA 1 ms 256 KB
test_C_77.txt AC 1 ms 256 KB
test_C_78.txt WA 1 ms 256 KB
test_C_79.txt WA 1 ms 256 KB
test_C_80.txt AC 1 ms 256 KB
test_C_81.txt WA 1 ms 256 KB
test_C_82.txt AC 1 ms 256 KB