티스토리 뷰
728x90
문제
https://www.acmicpc.net/problem/17471
풀이 및 소스코드
1. 조합으로 선거구 묶음 구하기 1개+n-1개, 2개+n-2개 이런식으로 나눠줌
for(int i=1;i<=n/2;i++) {
permu(0, 0, i);
}
2. 하나의 경우의 수가 완성이 되면, bfs를 통해서 서로 연결된 선거구인지 확인한다.
두 그룹 다 비교해준다.
Queue<Integer> q;
boolean[] v;
q = new LinkedList<>();
v = new boolean[n];
q.add(s.get(0));
v[s.get(0)] = true;
int count = 1;
while(!q.isEmpty()) {
int a = q.poll();
for(int b:g[a]) {
if(!v[b]&&s.contains(b)) {
//b를 방문하지 않았고, s에 b가 포함되어있다면
q.add(b);
v[b]=true;
count++;
}
}
}
if(count!=s.size()) return;
LinkedList<Integer> ns = new LinkedList<>();
for(int i=0;i<n;i++) {
if(s.contains(i)) continue;
ns.add(i);
}
q = new LinkedList<>();
v = new boolean[n];
q.add(ns.get(0));
v[ns.get(0)] = true;
count = 1;
while(!q.isEmpty()) {
int a = q.poll();
for(int b:g[a]) {
if(!v[b]&&ns.contains(b)) {
//b를 방문하지 않았고, ns에 b가 포함되어있다면
q.add(b);
v[b]=true;
count++;
}
}
}
if(count!=ns.size()) return;
3. 인구수 차이 비교
int po1 = 0;
int po2 = 0;
for(int i=0;i<s.size();i++) {
po1+=po[s.get(i)];
}
for(int i=0;i<ns.size();i++) {
po2+=po[ns.get(i)];
}
res = Math.min(res, Math.abs(po1-po2));
return;
전체 코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.Queue;
import java.util.StringTokenizer;
public class Main {
static int n;
static LinkedList<Integer>[] g;
static LinkedList<Integer> s = new LinkedList<>();
static int res = Integer.MAX_VALUE;
static int[] po;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st;
n = Integer.parseInt(br.readLine());
po = new int[n];
st = new StringTokenizer(br.readLine());
for(int i=0;i<n;i++) {
po[i] = Integer.parseInt(st.nextToken());
}
g = new LinkedList[n];
for(int i=0;i<n;i++) {
g[i] = new LinkedList<Integer>();
st = new StringTokenizer(br.readLine());
int m = Integer.parseInt(st.nextToken());
for(int j=0;j<m;j++) {
int a= Integer.parseInt(st.nextToken())-1;
g[i].add(a);
}
}
//1. 조합으로 선거구 묶음 구하기
for(int i=1;i<=n/2;i++) {
permu(0, 0, i);
}
if(res==Integer.MAX_VALUE) {
System.out.println("-1");
}else {
System.out.println(res);
}
}
public static void permu(int start, int cnt, int maxi) {
if(cnt == maxi) {
bfs_po_check();
return;
}
for(int i=start;i<n;i++) {
s.add(i);
permu(i, cnt+1, maxi);
s.remove(cnt);//넣고 빼주기
}
}
public static void bfs_po_check() {
Queue<Integer> q;
boolean[] v;
q = new LinkedList<>();
v = new boolean[n];
q.add(s.get(0));
v[s.get(0)] = true;
int count = 1;
while(!q.isEmpty()) {
int a = q.poll();
for(int b:g[a]) {
if(!v[b]&&s.contains(b)) {
//b를 방문하지 않았고, s에 b가 포함되어있다면
q.add(b);
v[b]=true;
count++;
}
}
}
if(count!=s.size()) return;
LinkedList<Integer> ns = new LinkedList<>();
for(int i=0;i<n;i++) {
if(s.contains(i)) continue;
ns.add(i);
}
q = new LinkedList<>();
v = new boolean[n];
q.add(ns.get(0));
v[ns.get(0)] = true;
count = 1;
while(!q.isEmpty()) {
int a = q.poll();
for(int b:g[a]) {
if(!v[b]&&ns.contains(b)) {
//b를 방문하지 않았고, ns에 b가 포함되어있다면
q.add(b);
v[b]=true;
count++;
}
}
}
if(count!=ns.size()) return;
//여기까지 왔으면 서로 연결되어있는 선거구라는 뜻!
//이제는 인구비교
int po1 = 0;
int po2 = 0;
for(int i=0;i<s.size();i++) {
po1+=po[s.get(i)];
}
for(int i=0;i<ns.size();i++) {
po2+=po[ns.get(i)];
}
res = Math.min(res, Math.abs(po1-po2));
return;
}
}
반응형
'Coding - Algo > Java' 카테고리의 다른 글
[백준] 1194번:달이 차오른다, 가자. (Java 자바) (0) | 2021.09.29 |
---|---|
[백준] 17281번:⚾ (Java 자바) (0) | 2021.09.28 |
[백준] 1755번:숫자놀이 (Java 자바) (0) | 2021.09.27 |
[백준] 17135번:캐슬 디펜스 (Java 자바) (0) | 2021.09.25 |
[백준] 17144번:미세먼지 안녕! (Java 자바) (0) | 2021.09.24 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 우분투
- 더 맵게
- 백준파이썬
- yoloV3
- 1240 자바
- 백준 17144
- 삼성청년SW아카데미
- poker swea
- ubuntu
- swea 1240
- SSAFY
- 3996 자바
- 프로그래머스 더 맵게
- 백준 dp 문제
- swea 1240 자바
- 타일링 자바
- swea 4070 타일링
- union-find
- 프로그래머스 자바
- swea 타일링 자바
- 파이썬 풀이
- 백준 풀이
- 파이썬
- 프로그래머스
- 메뉴리뉴얼 풀이
- 프로그래머스 파이썬
- 1699 자바
- SWEA
- swea 타일링
- 백준
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함