✏️기록하는 즐거움
article thumbnail

Link

 

2562번: 최댓값

9개의 서로 다른 자연수가 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 번째 수인지를 구하는 프로그램을 작성하시오. 예를 들어, 서로 다른 9개의 자연수 3, 29, 38, 12, 57, 74, 40, 85, 61 이 주어

www.acmicpc.net

문제

9개의 서로 다른 자연수가 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 번째 수인지를 구하는 프로그램을 작성하시오.
예를 들어, 서로 다른 9개의 자연수3, 29, 38, 12, 57, 74, 40, 85, 61이 주어지면, 이들 중 최댓값은 85이고, 이 값은 8번째 수이다.

입력 > 첫째 줄부터 아홉 번째 줄까지 한 줄에 하나의 자연수가 주어진다. 주어지는 자연수는 100 보다 작다.
출력 > 첫째 줄에 최댓값을 출력하고, 둘째 줄에 최댓값이 몇 번째 수인지를 출력한다.

 

| 예제 입력

3
29
38
12
57
74
40
85
61

| 예제 출력

85
8

 

제출

const input = (
  process.platform === "linux"
    ? require("fs").readFileSync("/dev/stdin").toString()
    : `3
    29
    38
    12
    57
    74
    40
    85
    61`
)
  .split("\n")
  .map(Number);

let count = 0;
let max = input[0];

for (let i = 1; i < 9; i++) {
  if (max < input[i]) {
    max = input[i];
    count = i;
  }
}

console.log(max);
console.log(count + 1);

 

풀이과정

for문을 사용해서 두 수를 비교한 후, 최댓값과 인덱스를 저장해 출력해주면 되는 간단한 문제이다.

 


Comment

얼마나 많은 것을 놓치고 문제를 풀고 있는지 알 수 있었다.

문제에서 제시한 '9개의 서로 다른 자연수''몇 번째 수인지'라는 키워드를 놓쳤다.

계속해서 input.length를 쓰고, count로 배열의 인덱스를 그대로 출력했다.

키워드를 놓치지 말기 !!

profile

✏️기록하는 즐거움

@nor_coding

포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!