https://www.acmicpc.net/problem/17610
17610번: 양팔저울
무게가 서로 다른 k개의 추와 빈 그릇이 있다. 모든 추의 무게는 정수이고, 그릇의 무게는 0으로 간주한다. 양팔저울을 한 번만 이용하여 원하는 무게의 물을 그릇에 담고자 한다. 주어진 모든 추
www.acmicpc.net
[난이도] Silver1
[유형] 브루트포스
[풀이]
추의 무게를 더하거나 빼서 만들 수 있는 모든 무게를 구해주면
이 무게들이 추를 이용해 만들 수 있는 무게들입니다.
#include <cstdio> int k,v[14],a[3000000],sum,ans; void sol(int n,int cur){ if(cur>=1) { if(!a[cur]) ans++; a[cur]=1; } if(n==k) return; sol(n+1,cur+v[n]); sol(n+1,cur-v[n]); sol(n+1,cur); } int main(){ scanf("%d",&k); for(int i=0;i<k;i++){ scanf("%d",&v[i]); sum+=v[i]; } sol(0,0); printf("%d",sum-ans); }
https://github.com/has2/Problem-Solving/blob/master/boj-solved.ac/Silver1/17610.cpp
'Problem-Solving > BOJ' 카테고리의 다른 글
[BOJ/백준][Gold1] 17612 : 쇼핑몰 (C++) (0) | 2022.07.04 |
---|---|
[BOJ/백준][Gold1] 17611 : 직각다각형 (C++) (0) | 2022.07.04 |
[BOJ/백준][Silver1] 17609 : 회문 (C++) (0) | 2022.07.04 |
[BOJ/백준][Bronze3] 17608 : 막대기 (C++) (0) | 2022.07.04 |
[BOJ/백준][Gold3] 2830 : 행성 X3 (C++) (0) | 2022.05.29 |