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
- CS Academy
- scc
- implementation
- 백준
- Eulerian path
- disjoint-set
- Shortest path
- bitmask
- Eulerian circuit
- Greedy
- DynamicProgramming
- hashing
- Segment Tree
- BOJ
- backtracking
- Sieve_of_Eratosthenes
- graph
- mathematics
- Dag
- Euler circuit
- graph modeling
- POJ
- BST
- flows
- GCD
- BFSDFS
- Cycle detecting
- Algospot
- Euler path
- dynamic programming
Archives
- Today
- Total
그냥 하는 노트와 메모장
BOJ 14258 - XOR 그룹 본문
* XOR 그룹
[ 분류 - DSU ]
CS Academy Round #9의 Array Removal이라는 문제를 먼저 푸는 것을 권장합니다.
1. 수가 작은 것 부터 제거해나가므로, 지우는 순서는 정해져 있다.
2. k번째 수를 제거했을 때의 XOR 그룹의 합 최대값과 k+1번째 수를 제거했을 때의 XOR 그룹의 합 최대값은 서로 종속적이다.
3. 지우는 과정에서 나오는 XOR 그룹의 합 최대가 되는 값을 출력한다.
삭제하는 순서대로 답을 도출해내기란 쉽지 않다. 따라서 문제 접근 방식을 조금 다르게 해야하는데, 삭제하는 과정 자체에 의미가 없다는 것을 깨닫는 것부터 시작한다. 무슨 소리나면, 1.처럼 순서는 정해져 있으며, 2.처럼 서로 종속적이기 때문에 종속의 의미 지니게끔 접근하는 것이다. 주어진 순서를 그대로 거꾸로 뒤집으면 종속 속성은 지니게끔 할 수 있다.
따라서 초기상태는 모두 지워진 상황에서 "큰 수"부터 추가하는 것이다. 큰 수를 추가해나감으로써 상하좌우 4방향에 대해 Union를 해주면 되시겠다. 그 중 현재 가장 큰 값과 합쳐서 나오는 값만을 확인해서 답을 도출해내면 된다. 어차피 가장 큰 값 하나만 원하므로 XOR union 할 때, 그 대상이 변경되는 것은 무시해도 상관 없기 때문이다.
'Solved problems' 카테고리의 다른 글
[Network flow, MCMF] Graph modeling practices - 백준 편 (2) | 2018.10.18 |
---|---|
[Network flow, MCMF] Graph modeling practices - Codeforce 편 (0) | 2018.09.29 |
CS Academy - Array Removal (0) | 2018.09.01 |
BOJ 2549 - 루빅의 사각형 (0) | 2018.08.07 |
Algospot - 정렬 게임(SORTGAME) (0) | 2018.07.03 |
Comments