2 - G 2910 자바 코드 공유합니다.
354
robin
작성한 질문수 5
1
한번에 정렬을 하면 될걸 시작부터 잘못 접근해서 개판이 난 코드입니다.
import java.util.*;
public class Prob2910 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
sc.nextInt();
Map<Integer,Integer> freqs = new HashMap<>(); // 숫자 - 빈도
Map<Integer,Integer> index = new HashMap<>(); // 숫자 - 첫 등장 위치
for (int i = 0; i < n; i++) {
int num = sc.nextInt();
if(freqs.containsKey(num)){
freqs.put(num, freqs.get(num)+1);
}else {
index.put(num,i);
freqs.put(num,1);
}
}
Map<Integer,List<Integer>> freqNums = new HashMap<>(); // 빈도 - 숫자들
for (int num: freqs.keySet()) {
int freq = freqs.get(num);
if(freqNums.containsKey(freq)){
freqNums.get(freq).add(num);
}else {
List<Integer> nums = new ArrayList<>();
nums.add(num);
freqNums.put(freq,nums);
}
}
for (List<Integer> nums: freqNums.values()) {
Collections.sort(nums, Comparator.comparingInt(index::get));
}
freqNums.keySet().stream().sorted(Comparator.reverseOrder()).forEach(key->{
List<Integer> list = freqNums.get(key);
list.forEach(e->{
int count = freqs.get(e);
for (int i = 0; i < count; i++) {
System.out.print(e+" ");
}
});
});
}
}해설 강의처럼 한번에 정렬을 하는 코드입니다.
import java.util.*;
public class Prob2910_sortOnce {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
sc.nextInt();
Map<Integer,Integer> numFreq = new HashMap<>();
Map<Integer,Integer> numFirstIndex = new HashMap<>();
List<Integer> nums = new ArrayList<>();
for (int i = 0; i < n; i++) {
int num = sc.nextInt();
nums.add(num);
if(numFreq.containsKey(num)){
numFreq.put(num,numFreq.get(num)+1);
}else {
numFreq.put(num,1);
numFirstIndex.put(num,i);
}
}
nums.sort((o1, o2) -> {
if (numFreq.get(o1).equals(numFreq.get(o2))) {
return numFirstIndex.get(o1) - numFirstIndex.get(o2);
} else {
return numFreq.get(o2) - numFreq.get(o1);
}
});
nums.forEach(e->System.out.print(e+" "));
}
}
답변 1
0
안녕하세요 robin님 공유 감사드립니다. ㅎㅎ
자바로 포팅하시면서 하는 것도 좋은 공부방법입니다.
질문 있으시면 언제든지 질문 부탁드립니다.
감사합니다.
강사 큰돌 올림.
1-E질문입니다!
0
518
2
3-L 틀린 부분 피드백 부탁드립니다.
0
822
2
1-A문제 순열재귀함수 질문입니다.
0
385
1
1-A 일곱난쟁이문제입니다
0
456
1
문제 풀 때 방향성에 대해
0
801
1
맥에서 vs code로 실행 관련 질문입니다
0
523
1
17071번 메모리 초과
0
386
1
1-C질문입니다!
0
421
2
2-B BFS 시간초과질문
0
630
2
1-O 13번 라인
0
442
1
6-J 놀이공원 문제 질문
0
381
1
구현관련 질문
0
484
1
강의 교안
0
319
1
실력을 더 올리고나서 강의를 보는 것이 맞을까요?
0
545
1
안녕하세요! 재귀함수에 관해서 질문드립니다
0
536
1
1-K
0
473
2
3-G번 질문있습니다.
1
473
3
3-C 실행 시간 질문드립니다.
0
494
1
4-A 문제 풀이 질문있습니다.
0
590
2
비트마스킹 연산자 "1의 보수" 영문 표기법
0
435
1
격자탐색 문제에서 BFS 시간복잡도 질문드립니다.
0
334
1
3-O go 함수 질문 드립니다.
1
447
2
4-A 출력 질문
0
305
1
1주차 1-O 질문드립니다
0
259
1





