Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 오블완
- constant buffre
- 잔디 기부
- root signature
- pcce 기출문제 9번 지폐 접기
- pccp 기출문제 풀이
- gemmasprint
- 티스토리챌린지
- pcce 기출문제 풀이
- pcce 기출문제 10번 공원 풀이
- DirectX12
- 코드트리 고대 문명 유적 탐사
- pcce 기출문제 10번 지폐 접기 풀이
- depth-stencil
- boj 1991
- texture mapping
- 프로그래밍공부
- python 고대 문명 유적 탐사
- 수식 복원하기
- DirectX
- boj 5567
- 잔디 기부 캠페인
- directx 그래픽스
- 고대 문명 유적 탐사
- 백준 5567
- c++ 5567
- pcce 기출문제 10번 공원
- 렌더링 파이프
- PCCE
- c++ 1991
Archives
- Today
- Total
오구의코딩모험
[Python] 14889번 : 스타트와 링크 본문
반응형
https://www.acmicpc.net/problem/14889
문제 3줄 요약
1. 짝수인 N명의 사람이 팀을 짜 축구를 한다.
2. 팀원들 간의 시너지가 존재한다. ex) 팀(1번 팀원 + 2번 팀원)의 능력치 = S12+ S21이다.
3. 팀 간 능력치의 차이가 최소가 되도록 팀을 짜봐라.
사람의 수인 N이 최대 20까지 이므로
브루트포스 알고리즘을 이용하였다.
최대 10 vs 10인 축구 경기가 될 것이다.
Step 1)
또한 경우의 수를 구하기 위해
조합 라이브러리인 combinations를 이용하였다.
Step 2)
팀원 간의 시너지는 두 명씩 존재하기에,
팀이 정해졌으면,
두 명씩 묶어 팀원간의 시너지를 더해 팀 능력치를 구해 비교한다.
Step 3)
스타트 팀과 링크 팀의 능력치 차이의 절댓값이
작은 경우를 갱신하여 최솟값을 찾는다.
from sys import stdin
from itertools import combinations
if __name__ == "__main__":
N = int(stdin.readline())
num_map, num_set, answer = [], set(), float('inf')
for idx in range(1,N+1):
num_map.append(list(map(int,stdin.readline().split())))
num_set.add(idx)
# Step 1) 팀 구성하기
com_list = list(combinations(num_set,N//2))
for idx in range(len(com_list)//2):
start_score = 0
# Step 2) 스타트팀 vs 링크팀
for s in combinations(com_list[idx],2):
start_score += num_map[s[0]-1][s[1]-1] + num_map[s[1]-1][s[0]-1]
link_score = 0
for l in combinations(num_set-set(com_list[idx]),2):
link_score += num_map[l[0]-1][l[1]-1] + num_map[l[1]-1][l[0]-1]
# Step 3) 능력치 차이의 최소 갱신
min_gap = abs(start_score - link_score)
if min_gap < answer:
answer = min_gap
if answer == 0:
break
print(answer)
축구 안한지 엄청 오래 된 것 같네
운동 좀 해야하는데..
여튼
끝!
반응형
'프로그래밍 공부 > 백준 알고리즘' 카테고리의 다른 글
[Python] 6588번 : 골드바흐의 추측 (2) | 2023.03.07 |
---|---|
[Python] 2485번 : 가로수 (0) | 2023.03.06 |
[Python] 2661번 : 좋은 수열 (0) | 2023.03.04 |
[Python] 1182번 : 부분수열의 합 (0) | 2023.03.02 |
[Python] 1406번 : 에디터 (0) | 2023.03.01 |
Comments