명의 학생들이 단체줄넘기를 하려고 한다. 단체줄넘기를 하기 위해서는 한 줄로 나란히 서야 하고, 학생들은 각자 줄을 잡은 양쪽 방향 중 한 곳을 바라보고 서야 한다.
학생들은 각자 바라보는 방향에 자신보다 키가 크거나 같은 사람이 있다면 점프할 타이밍을 놓쳐 줄에 걸릴 수 있다. 학생들은 최대한 많이 단체줄넘기를 뛰고 싶어 하기 때문에, 줄에 걸릴 수 있는 상황을 만들지 않으려고 한다. 즉 자신이 바라보는 방향에 자신보다 키가 작은 학생들만 앞에 오도록 줄을 서려고 한다.
학생들의 키를 알고 있을 때, 이 중 최대 몇 명의 학생이 단체줄넘기에 참여할 수 있을까? 줄을 돌리는 사람은 주어진 학생에 포함되지 않는다.
첫째 줄에 학생의 수 이 주어진다.
둘째 줄에 학생들의 키를 나타내는 정수 가 공백으로 구분되어 주어진다.
줄에 걸릴 수 있는 상황을 만들지 않도록 학생들을 적절히 배치했을 때, 단체줄넘기에 참여할 수 있는 최대 학생 수를 출력한다.
// let input = require('fs').readFileSync('/dev/stdin').toString().trim().split('\n');
let input = [10,
`1 3 2 4 2 4 4 3 2 7`];
let N = parseInt(input[0]);
let arr = input[1].split(' ').map(n=>parseInt(n));
arr.sort((a,b)=>a-b)
let answer = [];
answer.push(arr[0])
for(let i=1; i<N; i++){
if(arr[i]>arr[i-1]){
answer.push(arr[i])
}else{
if(answer.indexOf(arr[i])===answer.lastIndexOf(arr[i])){
answer.push(arr[i])
}
}
}
console.log(answer.length)
학생들의 키를 작은 순서대로 정렬한 후 앞에 있는 학생보다 클 경우에 추가되도록 하고,
같은 키일때 반대 방향으로 서는 경우가 한 번씩 더 있으므로 1명 더 추가 될 수 있도록 indexOf와 lastIndexOf가 같은 경우에만 추가하여 답을 구하였다.