문제
구단이 성적을 내지 못한다면 답은 새 선수 영입뿐이다. 이것은 오늘날 유럽 리그에서 가장 흔한 전략이고, 노르웨이의 로젠버그 팀은 이러한 전략이 성공한 대표적 예시다. 그들은 많은 스카우터들을 지구 곳곳에 파견해 가능성 있는 루키를 찾는다.
현재 첼시는 프리미어 리그에서 헤매고 있고, 결국 새로운 선수를 사기로 결정했다. 하지만 그들은 스카우터를 기다리기 지쳤고, 훨씬 더 효율적인 전략을 개발해냈다. "만약 무언가 팔리고 있다면, 그것에는 합당한 이유가 있다"는 배룸의 명언이 바로 그것이다. 축구에서 이 말은 곧 가장 비싼 선수가 가장 좋은 선수라는 이야기가 된다.
이에 따라 새로운 선수를 찾는 방법은 단순히 구단들에게 전화를 걸어 그들의 가장 비싼 선수를 사는게 되었다. 당신의 임무는 첼시가 리스트에서 가장 비싼 선수를 찾아낼 수 있도록 돕는 것이다.
입력
첫 번째 줄에는 테스트 케이스의 개수 n이 주어진다 (n≤100).
각 테스트 케이스의 첫 번째 줄 p는 고려해야될 선수의 수이다 (1≤p≤100).
그 아래 p개의 줄에는 선수의 정보가 표시된다.
각각의 줄은 선수의 가격 C 와 이름을 입력한다 (C<2*10의 9승).
- 모든 선수의 가격은 서로 다르다.
- 선수의 이름은 20자 이하여야 하며, 사이에 공백이 있어서는 안 된다.
출력
각각의 테스트 케이스에서 가장 비싼 선수의 이름을 출력해야한다.
예제 입력 1
2
3
10 Iversen
1000000 Nannskog
2000000 Ronaldinho
2
1000000 Maradona
999999 Batistuta
예제 출력 1
Ronaldinho
Maradona
코드
#include <stdio.h>
int main(){
int i, j;
int n; // 테스트 케이스의 개수 (n ≤ 100)
int p; // 고려해야될 선수의 수 (1 ≤ p ≤ 100)
int C[100]; // 선수의 가격
char player[100][21]; // 선수의 이름
int high_price; // 최고 가격
scanf("%d", &n);
for(i = 0; i < n; i++){
scanf("%d", &p);
high_price = 0;
for (j = 0; j < p; j++){
scanf("%d %s", &C[j], &player[j]);
if(high_price < C[j]){
high_price = C[j];
}
}
for (j = 0; j < p; j++){
if(high_price == C[j]){
printf("%s\n", player[j]);
}
}
}
return 0;
}
n번의 테스트 케이스가 끝날 때마다 가장 비싼 선수의 이름을 출력하는 코드이다.
1. 테스트 케이스 횟수 n을 입력한다.
2. 해당 테스트 케이스에서 고려할 선수의 수 p를 입력한다.
3. 고려할 선수의 수 p만큼 선수의 가격과 이름을 입력한다.
4. 선수와 가격이 입력될 때마다 high_price와 비교해 더 높은 가격이면 업데이트한다.
5. 모든 입력을 마치면 선수 리스트에서 high_price에 해당하는 선수를 출력한다.
#include <stdio.h>
int main(){
int i, j;
int n; // 테스트 케이스의 개수 (n ≤ 100)
int p[100]; // 고려해야될 선수의 수 (1 ≤ p ≤ 100)
int C[100][100]; // 선수의 가격
char player[100][100][20]; // 선수의 이름
int high_price[100]; // 최고 가격
scanf("%d", &n);
for(i = 0; i < n; i++){
scanf("%d", &p[i]);
high_price[i] = 0;
for (j = 0; j < p[i]; j++){
scanf("%d %s", &C[i][j], &player[i][j]);
if(high_price[i] < C[i][j]){
high_price[i] = C[i][j];
}
}
}
for(i = 0; i < n; i++){
for (j = 0; j < p[i]; j++){
if(high_price[i] == C[i][j]){
printf("%s\n", player[i][j]);
}
}
}
return 0;
}
n번의 테스트 케이스가 모두 끝나면 마지막에 각 테스트 케이스의 가장 비싼 선수의 이름을 출력하는 코드이며, 이외의 알고리즘은 동일하다.