브루트포스 문제
Bessie가 양질의 풀을 먹기위한 3 X 3의 가장큰 합의 구역을 구하고, 구역의 왼쪽 위 인덱스를 출력하라.
Brute 문제로 3X3이 되는 영역을 모두 구해보면 알 수 있다.

코드는 밑에 더보기를 클릭하시면 됩니다.
더보기
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.Arrays;
import java.util.Collections;
import java.util.StringTokenizer;
public class Main {
static int[][] c;
static int x;
static int y;
public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringBuilder sb = new StringBuilder();
StringTokenizer st = new StringTokenizer(br.readLine());
x = Integer.parseInt(st.nextToken());
y = Integer.parseInt(st.nextToken());
c = new int[x][y];
for(int i = 0; i < x; i++) {
st = new StringTokenizer(br.readLine());
for(int j = 0; j < y; j++) {
c[i][j] = Integer.parseInt(st.nextToken());
}
}
int max = 0;
int q = 0;
int w = 0;
for(int i = 0; i < x; i++) {
for(int j = 0; j < y; j++) {
int tmp = counting(i, j);
if(tmp > max) {
max = tmp;
q = i;
w = j;
}
}
}
sb.append(max + "\n" + (q + 1) + " " + (w + 1));
bw.write(sb.toString());
bw.flush();
bw.close();
br.close();
}
private static int counting(int i, int j) {
// TODO Auto-generated method stub
if(i + 3 >= x || j + 3 >= y) return 0;
int count = 0;
for(int q = i; q < i + 3; q++) {
for(int w = j; w < j + 3; w++) {
count += c[q][w];
}
}
return count;
}
}
'Baekjoon Online Judge' 카테고리의 다른 글
| 백준 17472 다리 만들기 2 자바 (0) | 2023.01.03 |
|---|---|
| 백준 16928 뱀과 사다리 게임 자바 (0) | 2023.01.03 |
| 백준 27008 Checking an Alibi 자바 (0) | 2023.01.01 |
| 백준 6191 Cows on Skates 자바 (0) | 2022.12.29 |
| 백준 12235 Data Packing (Large) 자바 (0) | 2022.12.29 |
댓글