LECTURE/BAEKJOON
[백준/자바] 1차원 배열 | 2562. 최댓값
heywoo
2023. 1. 18. 01:39
문제
9개의 서로 다른 자연수가 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 번째 수인지를 구하는 프로그램을 작성하시오.
예를 들어, 서로 다른 9개의 자연수
3, 29, 38, 12, 57, 74, 40, 85, 61
이 주어지면, 이들 중 최댓값은 85이고, 이 값은 8번째 수이다.
입력
첫째 줄부터 아홉 번째 줄까지 한 줄에 하나의 자연수가 주어진다. 주어지는 자연수는 100 보다 작다.
출력
첫째 줄에 최댓값을 출력하고, 둘째 줄에 최댓값이 몇 번째 수인지를 출력한다.
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int[] arr = new int[9];
for(int i = 0; i < arr.length; i++) {
arr[i] = sc.nextInt();
}
int max = arr[0]; //최대값
int maxi = 0;
for(int i = 0; i<arr.length; i++) {
if (arr[i] > max) {
max = arr[i];
maxi = i+1;
}
}
for(int i = 0; i < arr.length; i++) {
if (max == arr[i]) {
maxi = i+1;
}
}
System.out.println(max);
System.out.println(maxi);
}
}
메모
최대값 구하는 방법을 다시 찾아서 적용해봤다.
처음엔 배열이 9개인 걸 적용하는 것부터 헤맸고, max의 순서를 구하는 방법도 몰라서 찾아봤다.
의외로 간단한 거라 허탈하긴 했지만 잘 합쳐서 작성해봤는데 max 순서가 1 작게 나왔다.
그때 i는 0 부터 시작해서 +1을 해줘야 한다는 게 떠올라서 수정했더니 맞는 답이 나와서 제출했는데 틀렸다..
다른 사람들이 올린 질문을 보고 max 순서를 구하는 for 문을 따로 작성했더니 성공!