Skip to content

Commit 9384f9f

Browse files
committed
[Silver V] Title: 나이순 정렬, Time: 464 ms, Memory: 81824 KB -BaekjoonHub
1 parent 081d3a4 commit 9384f9f

File tree

2 files changed

+58
-0
lines changed

2 files changed

+58
-0
lines changed
Lines changed: 30 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
# [Silver V] 나이순 정렬 - 10814
2+
3+
[문제 링크](https://www.acmicpc.net/problem/10814)
4+
5+
### 성능 요약
6+
7+
메모리: 81824 KB, 시간: 464 ms
8+
9+
### 분류
10+
11+
정렬
12+
13+
### 제출 일자
14+
15+
2025년 1월 17일 15:05:55
16+
17+
### 문제 설명
18+
19+
<p>온라인 저지에 가입한 사람들의 나이와 이름이 가입한 순서대로 주어진다. 이때, 회원들을 나이가 증가하는 순으로, 나이가 같으면 먼저 가입한 사람이 앞에 오는 순서로 정렬하는 프로그램을 작성하시오.</p>
20+
21+
### 입력
22+
23+
<p>첫째 줄에 온라인 저지 회원의 수 N이 주어진다. (1 ≤ N ≤ 100,000)</p>
24+
25+
<p>둘째 줄부터 N개의 줄에는 각 회원의 나이와 이름이 공백으로 구분되어 주어진다. 나이는 1보다 크거나 같으며, 200보다 작거나 같은 정수이고, 이름은 알파벳 대소문자로 이루어져 있고, 길이가 100보다 작거나 같은 문자열이다. 입력은 가입한 순서로 주어진다.</p>
26+
27+
### 출력
28+
29+
<p>첫째 줄부터 총 N개의 줄에 걸쳐 온라인 저지 회원을 나이 순, 나이가 같으면 가입한 순으로 한 줄에 한 명씩 나이와 이름을 공백으로 구분해 출력한다.</p>
30+
Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
let fs = require('fs');
2+
let input = fs.readFileSync('/dev/stdin').toString().split('\n');
3+
4+
const n = Number(input[0]);
5+
let arr = [];
6+
for (let i = 1; i < n + 1; i++) {
7+
arr.push(input[i].split(' '));
8+
}
9+
10+
arr = arr.map((item, index) => [...item, index]);
11+
12+
arr.sort((a, b) => {
13+
if (Number(a[0]) !== Number(b[0])) {
14+
return Number(a[0]) - Number(b[0]);
15+
} else return a[2] - b[2];
16+
});
17+
18+
let answer = '';
19+
20+
arr.map((item) => {
21+
answer += item[0] + ' ' + item[1] + '\n';
22+
});
23+
24+
console.log(answer);
25+
26+
// 인덱스를 넣어서 가입 순서를 함께 저장
27+
// 나이순으로 그리고 가입 순서 순으로 정렬
28+
// 출력

0 commit comments

Comments
 (0)