CS/Algorithm
[BOJ][C++] 14500 테트로미노
별토끼.
2019. 2. 21. 12:16
반응형
[BOJ][C++] 14500 테트로미노
문제
https://www.acmicpc.net/problem/14500
풀이
테트리스 모형대로 DFS 탐색을 해줍니다.
DFS로 탐색할 때 사방 모두를 탐색하기 위해서 백트래킹을 이용했습니다.
그리고 ㅗㅓㅏㅜ만 따로 만들어서 탐색해주면 돼요. 이 때, 중앙 값을 기준으로 세 방면을 더해주고 maxVal과 비교하는 식으로 구했어요.
코드
#define _CRT_SECURE_NO_WARNINGS
#include <cstdio>
#include <algorithm>
using namespace std;
int n, m;
int map[500][500];
bool visited[500][500];
int maxVal = 0;
int dx[] = { -1,0,1,0,-1,0 };
int dy[] = { 0,-1,0,1,0,-1 };
void AnotherCase(int x, int y, int cnt, int val) {
//방향
for (int i = 0; i < 4; i++) {
int tmpval = val;
int tmpcnt = cnt;
for (int j = i; j <= i+2; j++) {
int nx = x + dx[j];
int ny = y + dy[j];
if (nx < 0 || ny < 0 || nx >= n || ny >= m) break;
tmpcnt++;
tmpval += map[nx][ny];
}
if ((maxVal < tmpval) && tmpcnt==4) {
maxVal = tmpval;
}
}
}
void DFS(int x, int y, int cnt, int val) {
if (cnt == 4) {
if (maxVal < val) {
maxVal = val;
}
return;
}
for (int i = 0; i < 4; i++) {
int nx = x + dx[i];
int ny = y + dy[i];
if (nx < 0 || ny < 0 || nx >= n || ny >= m) continue;
if (visited[nx][ny] == false) {
visited[nx][ny] = true;
val += map[nx][ny];
DFS(nx, ny, cnt + 1, val);
val -= map[nx][ny];
visited[nx][ny] = false;
}
}
}
int main() {
scanf("%d %d", &n, &m);
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
visited[i][j] = false;
}
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
scanf("%d", &map[i][j]);
}
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
visited[i][j] = true;
DFS(i, j, 1, map[i][j]);
AnotherCase(i, j, 1, map[i][j]);
visited[i][j] = false;
}
}
printf("%d\n", maxVal);
}
반응형