티스토리 뷰
https://www.acmicpc.net/problem/2629
2629번: 양팔저울
첫째 줄에는 추의 개수가 자연수로 주어진다. 추의 개수는 30 이하이다. 둘째 줄에는 추의 무게들이 자연수로 가벼운 것부터 차례로 주어진다. 같은 무게의 추가 여러 개 있을 수도 있다. 추의 무
www.acmicpc.net
이 문제의 핵심은 가지고 있는 추를 이용해서 확인할 수 있는 추의 무게를 모두 찾아내서 원하는 추의 무게가 있는지 없는지 확인하면 된다. 다이나믹 프로그래밍으로 분류되어있는 문제이지만 수의 제한(추의 개수는 최대 30개)이 크지 않기 때문에 완전탐색으로도 해결할 수 있다.
만약 추가 1이 있다고 하자. 무게 4인 추가 새로 추가된다고 하면 무게 1인 추와 무게 4인 추를 이용하여 확인할 수 있는 무게는
1. 추 자신의 무게 (1, 4)
2. 추 무게의 차이 (3)
3. 추 무게의 합 (5)
총 3가지 이다.
그러므로 추를 입력받을 때 마다 찾을 수 있는 추의 무게를 갱신해주면 된다. 중복인 무게가 들어와도 상관없지만 보기 좋게 set을 이용하여 중복인 무게를 제거하였다.
이후 찾고 싶은 무게의 추를 검사할 수 있으면 Y를 출력, 없으면 N을 출력하면 된다.
코드
import sys
input = sys.stdin.readline
n = int(input())
nums = list(map(int, input().split()))
candidate = []
for i in range(n):
if len(candidate) == 0:
candidate.append(nums[i])
else:
num = nums[i]
for j in range(len(candidate)):
diff = abs(num - candidate[j])
add = num + candidate[j]
candidate.append(num)
candidate.append(diff)
candidate.append(add)
candidate = list(set(candidate))
t = int(input())
test = list(map(int, input().split()))
ans = []
for tc in test:
if tc in candidate:
ans.append('Y')
else:
ans.append('N')
print(*ans)
'알고리즘' 카테고리의 다른 글
[프로그래머스] 경주로 건설 - 파이썬 (0) | 2022.08.27 |
---|---|
[백준] 1520 내리막길 - 파이썬 (0) | 2022.05.22 |
[백준] 6549 히스토그램에서 가장 큰 직사각형 - 파이썬 (0) | 2022.04.17 |
[백준] 12865 평범한 배낭 - 동적계획법과 냅색(Knapsack) (0) | 2022.04.05 |
[백준] 1463 1로만들기 - 파이썬 (0) | 2022.03.22 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 5주차 회고
- 피움 6주차 회고
- 8주차 회고
- 파이썬
- 회고
- jpa
- CI/CD
- 피움
- ZNS
- 스프링MVC
- 런칭 페스티벌
- 알림개선기
- 2차 데모데이
- 프로젝트
- 3차 데모데이
- Spring
- 우테코 회고
- 팀프로젝트
- ZNS SSD
- 스프링 프레임워크
- 스프링 부트
- 백준
- 우테코
- 환경 별 로깅 전략 분리
- 알림기능개선기
- java
- dm-zoned
- 네트워크
- 스프링 Logback
- dm-zoned 코드분석
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함