일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 조합
- 소프티어
- 루돌프의반란
- 백준
- 나무박멸
- 마이크로프로세서
- 이진탐색
- DenseDepth
- 마법의숲탐색
- 수영대회결승전
- 싸움땅
- 시뮬레이션
- BFS
- ros
- 구현
- 3Dreconstruction
- 슈퍼컴퓨터클러스터
- 포탑부수기
- dfs
- 코드트리
- 코드트리빵
- 순서대로방문하기
- ICER
- ISER
- 왕실의기사대결
- 토끼와 경주
- ARM
- 삼성기출
- DP
- Calibration
Archives
- Today
- Total
from palette import colorful_colors
[SWEA] 1949 등산로 조성 with C++ 본문
만약 등산로를 깎는 경우, 전역 MAP을 썼다면 복구시켜야 하는 백트래킹 문제!
깎았는지 / 안 깎았는지 여부를 재귀함수 매개변수에 추가로 넣어준다
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <vector>
#include <cstring>
#include <algorithm>
#include <stdio.h>
using namespace std;
int T, N, K, maxNumber, answer;
int MAP[9][9];
int visited[9][9];
int dy[4] = { -1, 1, 0, 0 };
int dx[4] = { 0, 0, -1, 1 };
struct Node{
int y;
int x;
};
vector <Node> startPoint;
void init() {
memset(MAP, 0, sizeof(MAP));
memset(visited, 0, sizeof(visited));
startPoint.clear();
maxNumber = 0;
answer = 0;
}
void input() {
cin >> N >> K;
for (int i = 0; i < N; i++)
{
for (int j = 0; j < N; j++)
{
cin >> MAP[i][j];
maxNumber = max(maxNumber, MAP[i][j]);
}
}
}
void dfs(int row, int col, int dist, int isUsed) {
for (int i = 0; i < 4; i++)
{
int ny = row + dy[i];
int nx = col + dx[i];
if (ny < 0 || nx < 0 || ny >= N || nx >= N)
continue;
if (visited[ny][nx] == 1)
continue;
// 지형 아직 안 깎았을때 - 깎거나, 그대로 두기
if (isUsed == 0) {
// 그대로 두는 경우
if (MAP[ny][nx] < MAP[row][col]) {
visited[ny][nx] = 1;
dfs(ny, nx, dist + 1, 0);
visited[ny][nx] = 0;
}
// 깎는 경우
for (int j = 1; j <= K; j++)
{
int temp = MAP[ny][nx]; // 만약 파낼때, 원래 깊이 복구하기 위해 만듬
MAP[ny][nx] -= j;
if (MAP[ny][nx] < MAP[row][col]) {
visited[ny][nx] = 1;
dfs(ny, nx, dist + 1, 1);
visited[ny][nx] = 0;
}
MAP[ny][nx] = temp;
}
}
// 지형 안 깎을때 - 깎이면 깎인채로, 안 깎이면 안 깎인채로
else {
if (MAP[ny][nx] < MAP[row][col]) {
visited[ny][nx] = 1;
if (isUsed == 1)
dfs(ny, nx, dist + 1, 1);
else
dfs(ny, nx, dist + 1, 0);
visited[ny][nx] = 0;
}
}
}
// 더 이상 갈 수 없을때 - 기저조건
if (answer < dist) {
answer = max(dist, answer);
}
return;
}
void solve() {
for (int i = 0; i < N; i++)
{
for (int j = 0; j < N; j++)
{
if (MAP[i][j] == maxNumber)
startPoint.push_back({i, j}); // 크기가 최대인 곳 스타트포인트에 저장
}
}
for (int i = 0; i < startPoint.size(); i++) // 스타트포인트에서 visited 초기화하고 출발하기
{
memset(visited, 0, sizeof(visited));
Node now = startPoint[i];
visited[now.y][now.x] = 1;
dfs(now.y, now.x, 1, 0);
}
}
int main() {
//freopen("sample_input.txt", "r", stdin);
cin >> T;
for (int tc = 1; tc <= T; tc++)
{
init();
input();
solve();
cout << "#" << tc << " " << answer << "\n";
}
return 0;
}
'알고리즘 > 문제풀이' 카테고리의 다른 글
[백준] 14502 연구소 with C++ (삼성기출) (0) | 2024.03.31 |
---|---|
[백준] 15683 감시 with C++ (삼성기출) (0) | 2024.03.31 |
[SWEA] 3234 준환이의 양팔저울 with C++ (0) | 2024.03.03 |
[백준] 16236 아기상어 with C++ (0) | 2024.02.22 |
[SWEA] 2382 미생물 격리 with C++ (0) | 2024.02.21 |