SW Expert Academy
SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!
swexpertacademy.com
DFS 완전 탐색
음.. DFS로 완전탐색하여 맛 점수 합의 최대값을 구하려고 했다.
처음 작성한 코드에서 시간 초과로 통과가 되지 않음
↓아래가 해당 코드이다↓
더보기
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<iostream> #include<vector> #include<algorithm> using namespace std; int result = 0; int N, L; vector<pair<int, int>> ingredients; void Hamburger(int calories, int score, vector<bool> visit) { vector<int> candidate; for (int i = N - 1; i >= 0; i--) { // 더 이상 방문할 수 없으므로, score 출력 if (visit[i] == false) { if ((calories - ingredients[i].second) < 0) { if (result < score) { //cout << score << "로 점수 갱신" << "\n"; result = score; } } else candidate.push_back(i); } } if (candidate.size() == 0) return; for (int index : candidate) { vector<bool> setVisit = visit; setVisit[index] = true; Hamburger(calories - ingredients[index].second, score + ingredients[index].first, setVisit); } } int main(int argc, char** argv) { int test_case; int T; //freopen("input.txt", "r", stdin); cin >> T; /* 여러 개의 테스트 케이스가 주어지므로, 각각을 처리합니다. */ for (test_case = 1; test_case <= T; ++test_case) { cin >> N >> L; vector<bool> visited; for (int i = 0; i < N; i++) { int score, calories; cin >> score >> calories; ingredients.push_back({ score, calories }); visited.push_back(false); } sort(ingredients.begin(), ingredients.end()); Hamburger(L, 0, visited); cout << "#" << test_case << " " << result << "\n"; } return 0;//정상종료시 반드시 0을 리턴해야합니다. } | cs |
뭐가 잘못된건지 다시봐도 모르겠어서, 다른 분들의 코드를 참고했다 ...
더보기
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 | vector<pair<int, int>> ingredients; //재료의 맛점수와 칼로리 vector<int> calories; vector<int> scores; int N, L; int maxFoodScore = -1; bool visited[21]; int caloriesSum() { int sum = 0; for (int i = 0; i < calories.size(); i++) sum += calories[i]; return sum; } int scoresSum() { int sum = 0; for (int i = 0; i < scores.size(); i++) sum += scores[i]; return sum; } void dfs(int n) { //현재까지 칼로리의 합이 제한 칼로리보다 높다면 종료 if (caloriesSum() > L) return; //현재까지 칼로리의 합이 제한 칼로리보다 작다면, 우선 맛점수 최대값 Set if (maxFoodScore < scoresSum()) maxFoodScore = scoresSum(); for (int i = n; i < ingredients.size(); i++) { // 아직 방문하지 않은 경우 진입 if (!visited[i]) { visited[true]; scores.push_back(ingredients[i].first); calories.push_back(ingredients[i].second); dfs(i + 1); visited[i] = false; scores.pop_back(); calories.pop_back(); } } } int main(int argc, char** argv) { int test_case; int T; //freopen("input.txt", "r", stdin); cin >> T; for (test_case = 1; test_case <= T; ++test_case) { cin >> N >> L; //N:재료의 수, L:제한 칼로리 for (int i = 0; i < N; i++) { int score, calories; cin >> score >> calories; ingredients.push_back({ score, calories }); } dfs(0); cout << "#" << test_case << " " << maxFoodScore << "\n"; ingredients.clear(); scores.clear(); ingredients.clear(); maxFoodScore = -1; } return 0;//정상종료시 반드시 0을 리턴해야합니다. } | cs |
내가 DFS를 좀 꼬아서 사용한 것 같긴하다..
또한 해당 문제는 0-1 knapsack 알고리즘으로 풀 수 있다고 하는데, 해당 개념을 다루고 넘어가자!
0-1 knapsack
먼저 Knapsack Problem이란, Dynamic Programming을 사용하는 기본적인 문제이다.
도둑이 보석가게에 배낭을 메고 침입했다.
배낭의 최대 용량은 W이며, 이를 초과해서 보석을 담으면 배낭이 찢어질 것이다.
각 보석들의 무게와 가격은 알고 있다.
배낭이 찢어지지 않는 선에서 가격 합이 최대가 되도록 보석을 담는 방법은?
따라서 $W$를 넘지않으면서 이득을 최대화하기 위해
각 보석을 넣을 것인지(1), 말 것인지(0) 결정하는 것!
DP는 전체의 큰 문제를 작은 문제로 쪼개어서 풀 수 있는지 확인하면 된다고 한다.
위 문제를 한 번 쪼개보자
- $w$는 배낭에 들어간 무게 (0<$w$<$W$)
- P[i][w]: $i$번째의 item까지 고려하였고, 무게의 한도가 $w$일 때 최적의 이익
1) 보석을 더 넣을 수 있긴 한 경우
1-1) 보석을 넣은 경우: P[$i-1$][$w - w_i$] + $p_i$
1-2) 보석을 넣지 않음: P[$i-1$][$w$]
2) 보석을 더 이상 넣을 수 없음($w_i$ > $w$) : P[$i-1$][$w$]
1)번 경우에서 최적의 방법을 판단하는 법은? 이득이 최대가 되는 것
따라서 P[i][w]의 점화식을 작성해보면 아래와 같다.
1 2 3 4 5 | if (wi <= w): max( P[i-1][w-wi] + pi , P[i-1][w]) else P[i-1][w] | cs |
c++로 5215번을 풀어보자!
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 | int main() { int T; cin >> T; for (int t = 0; t < T; t++) { // l = 제한 칼로리 cin >> n >> l; int score[21]; int cal[21]; for (int i = 1; i <= n; i++) { cin >> score[i] >> cal[i]; } for (int i = 1; i <= n; i++) { // 1 칼로리부터 최대 칼로리까지 확인함 for (int j = 1; j <= l; j++) { if (cal[i] > j) // 이번 순서의 재료 칼로리가 더 크다면, 못 넣음(이전 순서의 이득과 동일함) dp[i][j] = dp[i - 1][j]; else // 이번 순서의 재료 칼로리가 더 낮음. 새로 넣을 수 있는데 // 1) 이전 순서의 이득 과 // 2) 이전 순서 시점에서, 이번 재료 칼로리만큼 빠졌을 때 가질 수 있었던 점수 이득을 판단한다 // 1)이 더 우세하면 안 넣고 넘어가는 것이고, 아니라면 넣고 넘어간다. dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - cal[i]] + score[i]); cout << i << " " << j << "\n"; } } cout << "#" << t + 1 << " " << dp[n][l] << '\n'; } return 0; } | cs |
DP table이 어떻게 채워지는지 궁금해서 출력해보았음.. 궁금하면 펼치시오
더보기
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 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 | 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 1 2 0 0 0 0 0 0 0 0 0 0 0 0 0 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 1 3 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 1 4 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 1 5 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 1 6 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 1 7 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 1 8 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 1 9 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 1 10 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 1 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 2 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 3 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 4 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 5 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 6 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 7 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 8 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 9 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 2 10 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 1 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 2 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 3 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 4 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 5 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 6 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 7 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 8 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 9 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 3 10 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 1 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 2 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 3 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 4 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 5 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 6 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 7 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 8 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 0 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 9 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 0 0 0 0 0 0 0 0 0 0 0 0 ------- 4 10 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 0 0 0 0 0 0 0 0 0 ------- 5 1 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 0 0 0 0 0 0 0 0 0 ------- 5 2 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 100 0 0 0 0 0 0 0 0 ------- 5 3 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 0 0 0 0 0 0 0 ------- 5 4 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 400 0 0 0 0 0 0 ------- 5 5 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 400 400 0 0 0 0 0 ------- 5 6 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 400 400 500 0 0 0 0 ------- 5 7 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 400 400 500 650 0 0 0 ------- 5 8 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 400 400 500 650 650 0 0 ------- 5 9 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 400 400 500 650 650 750 0 ------- 5 10 0 0 0 0 0 0 0 0 0 0 0 0 0 100 100 100 100 100 100 100 100 100 0 0 100 100 100 300 300 400 400 400 400 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 250 350 350 400 550 550 650 0 0 100 250 400 400 500 650 650 750 750 ------- | cs |
'알고리즘 > SW Expert Academy' 카테고리의 다른 글
[SWEA] 2001. 파리 퇴치 (D2) / C++ (1) | 2023.11.09 |
---|---|
[SWEA] 1959. 두 개의 숫자열 (D2) / C++ (5) | 2023.11.08 |
[SWEA] 1206. [S/W 문제해결 기본] 1일차 - View (D3) / C++ (1) | 2023.11.01 |
[SWEA] 1859. 백만장자 프로젝트 (D2) / C++ (0) | 2023.11.01 |
[SWEA] 1204. [S/W 문제해결 기본] 1일차 - 최빈수 구하기(D2) / C++ (0) | 2023.11.01 |