Algorithm

백준 1080 : 행렬

쿠케캬캬 2021. 11. 16. 13:15
반응형

https://www.acmicpc.net/problem/1080

 

1080번: 행렬

첫째 줄에 행렬의 크기 N M이 주어진다. N과 M은 50보다 작거나 같은 자연수이다. 둘째 줄부터 N개의 줄에는 행렬 A가 주어지고, 그 다음줄부터 N개의 줄에는 행렬 B가 주어진다.

www.acmicpc.net

 

왼쪽 위에서부터 서로 값이 다르다면 뒤집는 연산을 수행해주었습니다.

 

#include <cstdio>

int n, m, ans = 0;
char a[50][51], b[50][51];

void input(char c[][51]) {
	for (int i = 0; i < n; i++)
		scanf("%s", c[i]);
}

void reverse(int x, int y) {
	for (int i = x; i < x + 3; i++)
		for (int j = y; j < y + 3; j++)
			a[i][j] = a[i][j] == '1' ? '0' : '1';
}

int isEquals() {
	for (int i = 0; i < n; i++)
		for (int j = 0; j < m; j++)
			if (a[i][j] != b[i][j]) return -1;
	return ans;
}

int main() {
	scanf("%d %d", &n, &m);
	input(a);
	input(b);
	for (int i = 0; i < n - 2; i++)
		for (int j = 0; j < m - 2; j++)
			if (a[i][j] != b[i][j])
				reverse(i, j), ans++;
	printf("%d", isEquals());
}
반응형