본문 바로가기

Study/BOJ

(12)
BOJ - 모노미노도미노 2 이 문제는 그림으로 하나하나 어떻게 동작하는지 잘 설명해주어서 이해하기가 조금은 수월했다. '조금'이라는 표현을 한 이유는 문제에서 일어날 수 있는 다양한 예시를 보여줬다기 보다는 어떤 한 예시를 통해 각각의 단계별로 보여줬기 때문에 테스트 케이스를 다 통과한다 할지라도 틀릴 수 있고, 구현이 잘못된 부분이 있을지라도 테스트 케이스를 통과할 수 있었다. (예를 들면, blue칸에서 이동하는 것을 잘못 짰는데 blue에서 그런 이동이 없는 경우 테스트 케이스를 돌리더라도 발견할 수 없다.) 물론 이러한 예외 사항들은 본인이 직접 찾아가며 하는 것이 당연하지만 그냥 투정이라고 생각해주면 좋겠다. 코드 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 ..
BOJ - 사다리 조작(15684) i 번 세로선의 사다리 게임 결과가 i가 되게 하기 위해 최대 3개의 가로선을 추가할 수 있다고 할 때 백트래킹을 이용하여 모든 경우를 완전탐색하는 문제이다. 코드 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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 #include using namespace std; int N, M, H; bool ladder[31][11]; int add; bool finish; void..
BOJ - 구슬 탈출 2(13460) 코드 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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126..
BOJ - 어른 상어(19237) 코드 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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126..
BOJ - 행성 터널(2887) 처음에 이 문제를 접했을 때, 사실 왜 gold 1이나 부여되어 있는지 몰랐는데 그대로 제출하니 메모리 초과가 발생하였다. N이 10만개가 들어왔을 경우 내 알고리즘은 현재 N * (N-1)개 만큼의 간선정보를 저장하고 있다. 하지만, 이 문제는 모든 간선에 대한 정보를 알 필요 없이 x축, y축, z축에 대해 인접한 행성만 보면 된다. 그 이유는 백준 질문게시판에 나와있는 아래 내용과 같다. 주어진 그래프의 MST를 T라고 합시다. 인접하지 않은 정점 A, B가 T에서 간선으로 연결되어있다고 가정하죠. 일반성을 잃지 않고 A, B 사이에 연결된 간선 무게가 |A_x - B_x| 라고 하죠. x 축으로 A, B 사이에 있는 정점 C가 존재합니다 (A_x c.z; c.idx = i + 1; v.push_b..
BOJ - 다리 만들기 2(17472) 삼성 SWEA A형 기출문제고, MST에 관련한 문제여서 풀어보았다. 코드 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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 ..
BOJ - 네트워크 연결(1922) 코드 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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 #include #include #include using namespace std; int N, M, answer; typedef struct graph { int v1; int v2; int cost; } graph; vector v; bool comp(graph a, graph b) { return a.cost N; cin ..
BOJ - 거짓말(1043) 코드 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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 #include #include using namespace std; int N, M; vector party[51]; int getRoot(vector parent, int idx) { if (parent[idx] == idx) return idx; else return..