inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비

4. 최대수입스케쥴( PriorityQueue)

테스트 케이스 추가 질문

280

leejohy

작성한 질문수 4

0

안녕하세요! 아래와 같이 구현하였는데, 주어진 케이스만으로는 검증이 되지 않아서요! 혹시 다른 케이스 제공 부탁드려도 될까요?

- 구현 -

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);
}
}

java 코테 준비 같이 해요!

답변 2

1

김태원

안녕하세요^^

반례입니다.

10

13 2

18 1

68 10

72 8

11 7

41 2

48 7

15 7

34 1

13 8

답은 302입니다.

0

leejohy

바쁘실텐데 답변 감사드립니다! 원인을 찾았네요~~

안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.

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