| 일 | 월 | 화 | 수 | 목 | 금 | 토 | 
|---|---|---|---|---|---|---|
| 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 | 29 | 30 | 31 | 
													Tags
													
											
												
												- 멀티프로세서
- 디자인패턴
- DirectX12
- 쓰레드
- 다이나믹프로그래밍
- 컨디션 변수
- 프로그래머스
- 백준
- 스케줄링
- OS
- I/O장치
- 병행성
- 파일시스템 구현
- 렌더링 파이프라인
- 그리디 알고리즘
- 자료구조
- 알고리즘
- 운영체제
- 타입 객체
- 동적계획법
- directx
- 멀티쓰레드
- codility
- 그리디알고리즘
- Direct12
- 락
- 다이나믹 프로그래밍
- DirectX 12
- 병행성 관련 오류
- 영속성
													Archives
													
											
												
												- Today
- Total
기록공간
대회 or 인턴 (백준 - 2875번) 본문
반응형
    
    
    
  
우선 최대 구성할 수 있는 팀 수를 구한다. 그리고 인턴쉽 프로그램에 참여하는 수를 남은 학생 수와 빼준다. 하지만 그래도 인턴쉽에 참여해야 할 수가 남아 있으면 구성한 팀에 있는 학생에서 채우면 된다.
남은 인턴쉽 참여 인원을 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
			
		
	
               
           
					
					
					
					
					
					
				 
								 
								 
								