일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 페이코 추천인코드
- C언어
- SWEA
- php 프로그래밍 입문 문제풀이
- 플러터 개발환경 설정
- 자바 스프링
- 최단 경로
- php 프로그래밍
- php 프로그래밍 입문 3판
- php
- 페이코 초대코드
- 페이코 추천인
- programmers
- 페이코 친구코드
- 스프링
- php 프로그래밍 입문 솔루션
- 백준
- JAVA SPRING
- 배열
- Java
- 한정 분기
- Flutter
- 플러터
- C
- 자바
- php 프로그래밍 입문 예제
- 파이썬
- spring
- php 프로그래밍 입문
- php 프로그래밍 입문 연습문제
Archives
- Today
- Total
11-07 11:40
ImJay
[SWEA/Java] 5215. 햄버거 다이어트 - 부분집합 풀이 본문
반응형
[SWEA/Java] 5215. 햄버거 다이어트 - 부분집합 풀이
풀이
package edu.ssafy.im.SWEA.D3.No5215;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Solution_PowerSet {
int n, l, ans;
int[] happy, score;
public static void main(String[] args) throws IOException {
new Solution_PowerSet().sol();
}
private void sol() throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringBuilder sb = new StringBuilder();
int testCase = Integer.parseInt(br.readLine());
for (int t = 1; t <= testCase; t++) {
// 입력 받기
String input = br.readLine();
StringTokenizer st = new StringTokenizer(input);
n = Integer.parseInt(st.nextToken()); // 재료의 수
l = Integer.parseInt(st.nextToken()); // 제한 칼로리
happy = new int[n]; // 재료의 맛에 대한 점수 배열
score = new int[n]; // 재료의 칼로리 배열
for (int i = 0; i < n; i++) {
input = br.readLine();
st = new StringTokenizer(input);
happy[i] = Integer.parseInt(st.nextToken());
score[i] = Integer.parseInt(st.nextToken());
}
ans = 0; // 최종 결과 초기화
powerSet(0, new boolean[n]); // 부분집합 구하기
// 결과 출력
sb.append("#").append(t).append(" ").append(ans).append("\n");
}
System.out.println(sb);
}
private void powerSet(int idx, boolean[] sel) {
// basis part
if (idx == n) { // 모든 재료를 선택했을 때
int happySum = 0, scoreSum = 0;
// 선택된 재료의 맛과 칼로리 계산
for (int i = 0; i < sel.length; i++) {
if(sel[i]) {
happySum += happy[i];
scoreSum += score[i];
}
}
// 제한 칼로리를 초과하면 종료
if (scoreSum > l)
return;
// 현재까지의 최대 맛 갱신
if (happySum > ans)
ans = happySum;
return;
}
// inductive part
// 현재 재료를 선택한 경우
sel[idx] = true;
powerSet(idx + 1, sel);
// 현재 재료를 선택하지 않은 경우
sel[idx] = false;
powerSet(idx + 1, sel);
}
}
반응형
'알고리즘 > BOJ - Java' 카테고리의 다른 글
[BOJ/Java] 12891. DNA 비밀번호 (0) | 2024.02.04 |
---|---|
[BOJ/Java] 2961. 도영이가 만든 맛있는 음식 (2) | 2024.02.04 |
[BOJ/Java] 15651. N과 M (3) (0) | 2024.02.04 |
[BOJ/Java] 15650. N과 M (2) (0) | 2024.02.04 |
[BOJ/Java] 11660. 구간 합 구하기 5 (0) | 2024.02.04 |
Comments