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 문을 따로 작성했더니 성공!