BOJ - 18430번 무기공학 (C++)

woga·2020년 12월 10일
0

BOJ

목록 보기
81/83
post-thumbnail
post-custom-banner

문제 출처: https://www.acmicpc.net/problem/18430

난이도

Silver 1


접근법

백트랙킹을 이용했다. 그리고 ㄱ모양으로 이어지기 때문에 일일이 조건문을 걸어 계산했다.


통과 코드

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>


using namespace std;

int arr[6][6];
bool ch[6][6];
int N, M;
int res = 0;

void dfs(int x, int y, int sum) {
	if (y == M) {
		y = 0;
		x++;
	}
	if (x == N) {
		res = max(res, sum);
		return;
	}
	if (!ch[x][y]) {
		if (x + 1 < N && y - 1 >= 0 && !ch[x + 1][y] && !ch[x][y - 1]) {
			ch[x + 1][y] = true;
			ch[x][y - 1] = true;
			ch[x][y] = true;
			int tmp = sum + (arr[x + 1][y] + (arr[x][y] * 2) + arr[x][y - 1]);
			dfs(x, y + 1, tmp);
			ch[x + 1][y] = false;
			ch[x][y - 1] = false;
			ch[x][y] = false;
		}
		if (x - 1 >= 0 && y - 1 >= 0 && !ch[x - 1][y] && !ch[x][y - 1]) {
			ch[x - 1][y] = true;
			ch[x][y - 1] = true;
			ch[x][y] = true;
			int tmp = sum + (arr[x - 1][y] + (arr[x][y] * 2) + arr[x][y - 1]);
			dfs(x, y + 1, tmp);
			ch[x - 1][y] = false;
			ch[x][y - 1] = false;
			ch[x][y] = false;
		}
		if (x - 1 >= 0 && y + 1 < M && !ch[x - 1][y] && !ch[x][y + 1]) {
			ch[x - 1][y] = true;
			ch[x][y + 1] = true;
			ch[x][y] = true;
			int tmp = sum + (arr[x - 1][y] + (arr[x][y] * 2) + arr[x][y + 1]);
			dfs(x, y + 1, tmp);
			ch[x - 1][y] = false;
			ch[x][y + 1] = false;
			ch[x][y] = false;
		}
		if (x + 1 < N && y + 1 < M && !ch[x + 1][y] && !ch[x][y + 1]) {
			ch[x + 1][y] = true;
			ch[x][y + 1] = true;
			ch[x][y] = true;
			int tmp = sum + (arr[x + 1][y] + (arr[x][y] * 2) + arr[x][y + 1]);
			dfs(x, y + 1, tmp);
			ch[x + 1][y] = false;
			ch[x][y + 1] = false;
			ch[x][y] = false;
		}
	}
	dfs(x, y + 1, sum);
}

int main() {
	cin >> N >> M;
	for (int i = 0; i < N; i++) {
		for (int j = 0; j < M; j++) {
			cin >> arr[i][j];
		}
	}
	
	dfs(0,0,0);
	cout << res << "\n";
	return 0;
}
profile
와니와니와니와니 당근당근
post-custom-banner

0개의 댓글