# 문제
# 코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class BOJ2566_v1 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int[][] numArr = new int[9][9]; // 9x9 행렬 선언
int max = 0;
int[] nums = new int[2]; // max값 위치 구하기 위한 변수
for (int i = 0; i < 9; i++) {
String[] inputArr = br.readLine().split(" ");
for (int j = 0; j < 9; j++) {
numArr[i][j] = Integer.parseInt(inputArr[j]);
// 가장 큰 수와 위치 구하는 계산
if (numArr[i][j] > max) {
max = numArr[i][j];
nums[0] = i;
nums[1] = j;
}
}
}
System.out.println(max); // 가장 큰 값 출력
for (int num : nums) { // 가장 큰 값 위치 출력
System.out.print(num + 1 + " ");
}
}
}
# 입/출력 결과
# 과정
- BufferedReader로 입력값 받기.
- int[][] numArr에 9x9 행렬 크기로 선언
- 가장 큰 값을 담을 int max를 선언하고 0으로 초기화.
- max가 위치한 행렬 위치를 담기 위한 int[] nums를 2 크기로 선언
- for문을 사용하여 i를 9번 반복하고, 반복할 때마다 입력값을 받기. 입력값은 공백 기준으로 나누어 String[] inputArr에 저장.
- 이중 for문으로 j를 9번 반복하고, numArr[i][j]에 inputArr[j] 값을 순차적으로 저장.
- 그리고 if문을 사용하여 numArr[i][j]가 max보다 크면 max에 numArr[i][j]를 저장하고 i와 j를 nums에 0번째, 1번째에 값을 저장.
- max값과 nums의 값을 출력.
# 메모
- 이번 문제도 거뜬히 해결했다. o_o v !!!
'코딩 테스트' 카테고리의 다른 글
[코딩테스트] 백준 2563번: 색종이 (0) | 2025.06.26 |
---|---|
[코딩테스트] 백준 10798번: 세로읽기 (0) | 2025.06.25 |
[코딩테스트] 백준 2738번: 행렬 덧셈 (0) | 2025.06.22 |
[코딩테스트] 백준 25206번: 너의 평점은 (0) | 2025.06.21 |
[코딩테스트] 백준 1316번: 그룹 단어 체커 (0) | 2025.06.20 |