240724 행렬 제곱

Jongleee·2024년 7월 24일
0

TIL

목록 보기
633/786
static int n;
static long b;
static int[][] matrix;

public static void main(String[] args) throws IOException {
	BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
	StringTokenizer st = new StringTokenizer(br.readLine());

	n = Integer.parseInt(st.nextToken());
	b = Long.parseLong(st.nextToken());
	matrix = new int[n][n];
	for (int i = 0; i < n; i++) {
		st = new StringTokenizer(br.readLine());
		for (int j = 0; j < n; j++) {
			matrix[i][j] = Integer.parseInt(st.nextToken()) % 1000;
		}
	}

	int[][] result = matrixPower(matrix, b);

	StringBuilder sb = new StringBuilder();
	for (int[] row : result) {
		for (int val : row) {
			sb.append(val).append(" ");
		}
		sb.append("\n");
	}
	System.out.print(sb);
}

private static int[][] matrixPower(int[][] base, long exp) {
	if (exp == 1) {
		return base;
	}
	int[][] result = matrixPower(base, exp / 2);
	result = multiplyMatrices(result, result);

	if (exp % 2 == 1) {
		result = multiplyMatrices(result, base);
	}

	return result;
}

private static int[][] multiplyMatrices(int[][] a, int[][] b) {
	int n = a.length;
	int[][] result = new int[n][n];

	for (int r = 0; r < n; r++) {
		for (int c = 0; c < n; c++) {
			int temp = 0;
			for (int i = 0; i < n; i++) {
				temp += a[r][i] * b[i][c];
			}
			result[r][c] = temp % 1000;
		}
	}

	return result;
}

출처:https://www.acmicpc.net/problem/10830

0개의 댓글