250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 백준#BOJ#14501#퇴사#브루트포스
- 백준#BOJ#8012#한동이는영업사원
- 백준#BOJ#2615#오목
- 백준#BOJ#1939#중량제한
- 백준#boj#12755
- 백준#boj#16932#모양만들기
- 백준#BOJ#12865#평범한배낭
Archives
- Today
- Total
순간을 성실히, 화려함보단 꾸준함을
[ boj : 22252 ] 정보 상인 호석 본문
https://www.acmicpc.net/problem/22252
해설 : 그냥 적당한 구현문제입니다.
처음에 알고리즘 시작할때 하나의 key 값에 여러개의 정보를 저장할때 어떻게 해야될지 몰라서 해맸던 기억이 있습니다.
방법은 map을 하나 선언해주고 value 값으로 vector,set,priority_queue 등등 을 선언해 주면됩니다.
전 여기서 가장 큰 값을 순차적으로 뽑는것이니 priority_queue 를 선언해서 문제를 해결하였습니다.
하 자바 너무 싫어요 ㅠㅠㅠㅠ
/**
* IO Template reference : 류호석
*/
import java.io.*;
import java.util.*;
import static java.lang.Math.*;
public class Main {
static FastReader scan = new FastReader();
public static void main(String[] args) {
int t=1;
//t = scan.nextInt();
while(t-->0)
solve();
}
static void solve() {
int q;
q = scan.nextInt();
Map<String, PriorityQueue> mp = new HashMap<>();
long ans=0;
int f,k,c;
String name;
for(int i=0;i<q;i++){
f = scan.nextInt();
name = scan.next();
if(f==1){
k = scan.nextInt();
PriorityQueue<Integer> pq;
if(!mp.containsKey(name)){
pq = new PriorityQueue<>((x,y)->y-x);
}else{
pq = mp.get(name);
}
for(int j=0;j<k;j++){
c = scan.nextInt();
pq.add(c);
mp.put(name,pq);
}
}
else{
k=scan.nextInt();
if(!mp.containsKey(name)) continue;
for(int j=0;j<k && !mp.get(name).isEmpty();j++) {
ans += (Integer)mp.get(name).peek();
mp.get(name).poll();
}
}
}
System.out.println(ans);
}
static class FastReader{
BufferedReader br;
StringTokenizer st;
public FastReader(){
br = new BufferedReader(new InputStreamReader(System.in));
}
public FastReader(String s) throws FileNotFoundException {
br = new BufferedReader(new FileReader(new File(s)));
}
String next(){
while(st==null || !st.hasMoreElements()){
try{
st = new StringTokenizer(br.readLine());
}catch(IOException e){
e.printStackTrace();
}
}
return st.nextToken();
}
int nextInt(){
return Integer.parseInt(next());
}
double nextDouble(){
return Double.parseDouble(next());
}
long nextLong(){
return Long.parseLong(next());
}
String nextLind(){
String str="";
try{
str=br.readLine();
}catch (IOException e){
e.printStackTrace();
}
return str;
}
}
}
'알고리즘,SQL > 백준,BOJ' 카테고리의 다른 글
[ boj : 23559 ] 밥 (2) | 2021.12.10 |
---|---|
[ boj : 22254 ] 공정 컨설턴트 호석 (0) | 2021.12.01 |
[ boj : 22251 ] 빌런 호석 (0) | 2021.11.23 |
[ boj : 14746 ] Closet Pair (0) | 2021.11.21 |
[ boj : 16947 ] 서울 지하철 2호선 (0) | 2021.11.20 |