테스트 케이스 추가 질문
280
작성한 질문수 4
안녕하세요! 아래와 같이 구현하였는데, 주어진 케이스만으로는 검증이 되지 않아서요! 혹시 다른 케이스 제공 부탁드려도 될까요?
- 구현 -
1. ArrayList의 time 부분을 해시맵으로 구현 -> time 종류의 수를 통해 그 수만큼만 반복하도록 while문을 구현하였습니다.(테스트 케이스의 경우 1, 2, 3 으로 3종류이므로 3번 반복)
2. 0번째, 즉 ArrayList의 맨 앞의 부분을 반복 이전에 미리 빼두었습니다.
3. while 내에 for문을 통해 i를 갱신하며 이전에 탐색했던 부분은 지나가도록 구현하였습니다.
import java.io.IOException;
import java.util.*;
class Pay {
int money;
int time;
public Pay(int money, int time) {
this.money = money;
this.time = time;
}
}
public class Main {
public static void main(String[] args) throws IOException {
Main T = new Main();
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
HashMap<Integer, Integer> hm = new HashMap<>();
ArrayList<Pay> arr = new ArrayList<>();
for (int i = 0; i < n; i++) {
int m = sc.nextInt();
int t = sc.nextInt();
hm.put(t, hm.getOrDefault(hm.get(t), 0)+1);
arr.add(new Pay(m, t));
}
Collections.sort(arr, new Comparator<Pay>() {
@Override
public int compare(Pay o1, Pay o2) {
if(o2.time == o1.time) {
return o2.money - o1.money;
} else
return o2.time - o1.time;
}
});
PriorityQueue<Integer> pQ = new PriorityQueue<>(Collections.reverseOrder());
int day = arr.get(0).time;
int key = hm.size();
int j = 1;
int result = 0;
pQ.offer(arr.get(0).money);
while(key > 0) {
for(int i=j; i<arr.size(); i++) {
if(day == arr.get(i).time) {
pQ.offer(arr.get(i).money);
} else {
day=arr.get(i).time;
j = i;
break;
}
}
key --;
result += pQ.poll();
}
System.out.println(result);
}
}
답변 2
안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.
0
71
2
갑자기 채점 사이트가 바뀌었어요
0
50
1
문제 리스트 페이지
0
43
1
채점 사이트 관련 질문드립니다
0
41
1
봉우리 문제 질문입니다
0
102
2
씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?
0
73
0
이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?
0
78
0
가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법
0
76
1
좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ
0
94
2
6-7 강의에서
0
53
1
6-6. 장난꾸러기 질문 있습니다.
0
50
1
강의 수강후 코딩테스트
0
126
1
answer 변수 사용 여부
0
50
1
2중 for문
1
96
2
2-11. 임시반장정하기 (Runtime Error)
0
67
1
혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?
0
75
1
이런 풀이는 어떨까요
0
50
1
자바 스트림 방식의 효율성 질문 드립니다.
0
62
1
알고리즘 자료 구조들..
0
68
1
StringBuilder vs BufferdWriter
0
53
1
원더랜드(프림)
0
55
1
이런 코드는 어떤가요?
0
66
1
bfs 풀이
0
62
1
병합정렬
0
58
1





