기록공간

대회 or 인턴 (백준 - 2875번) 본문

Algorithm/문제

대회 or 인턴 (백준 - 2875번)

입코딩 2020. 2. 11. 13:22
반응형

우선 최대 구성할 수 있는 팀 수를 구한다. 그리고 인턴쉽 프로그램에 참여하는 수를 남은 학생 수와 빼준다. 하지만 그래도 인턴쉽에 참여해야 할 수가 남아 있으면 구성한 팀에 있는 학생에서 채우면 된다. 

 

남은 인턴쉽 참여 인원을 3으로 나누면 인턴쉽을 보내야 할 팀 수가 나오며, 3으로 나누었을때 한 팀이 또 깨지게 되므로 구한 팀 수에서 1을 더한다. 그리고 앞서 구했던 최대 구성 팀수와 빼주면 된다.

 

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
	int girl, boy;
	int intern;

	cin >> girl >> boy >> intern;

	int maxTeam = 0;

	int tGirl = girl;
	int tBoy = boy;

	while (true)
	{
		tGirl -= 2;
		tBoy -= 1;

		if (0 > tGirl || 0 > tBoy)
			break;
		
		++maxTeam;
	}

	intern -= (girl + boy) - (3 * maxTeam);
	
	int notTeam = 0;
	if (0 < intern)
	{
		notTeam = intern / 3;
		if (0 != intern % 3)
			++notTeam;
	}

	maxTeam -= notTeam;

	cout << maxTeam << endl;
}
반응형

'Algorithm > 문제' 카테고리의 다른 글

문자열 (백준 - 1120번)  (0) 2020.02.12
잃어버린 괄호 (백준 - 1541번)  (0) 2020.02.11
30 (백준 - 10610번)  (0) 2020.02.11
거스름돈 (백준 - 5585번)  (0) 2020.02.08
로프 (백준 - 2217번)  (0) 2020.02.08
Comments