📜 코딩테스트/BAEKJOON\정렬

백준(Baekjoon) 2751번 : 수 정렬하기 2 (JAVA) 문제 풀이

2020. 11. 15. 21:25
목차
  1.  
  2.  
  3. 🚀문제
  4. 💬 예제 입력           
  5. 💬 예제 출력
  6.  
  7.  
  8. 🌈 나의 풀이
  9. Merge Sort 사용
  10. Counting Sort 사용
  11. Collections.sort() 를 사용
반응형

www.acmicpc.net/problem/2751

 

2751번: 수 정렬하기 2

첫째 줄에 수의 개수 N(1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄부터 N개의 줄에는 숫자가 주어진다. 이 수는 절댓값이 1,000,000보다 작거나 같은 정수이다. 수는 중복되지 않는다.

www.acmicpc.net

 


 

🚀문제

 

💬 예제 입력           

5
5
4
3
2
1             

💬 예제 출력

1
2
3
4
5

 

 

🌈 나의 풀이

문제를 보고 당연히 Arrays.sort() 를 사용하려 했지만,, 시간 초과.

퀵 정렬은 평균 시간 복잡도가   O(nlogn)   이지만,  최악의 경우 O(n2)  까지 될 수도 있다.

일부러 퀵 정렬을 못쓰게 하려고 한 데이터가 있는 것 같다. ( 그럼 다른거 쓰면 되지🙃)

 

Merge Sort 사용

X

 

Counting Sort 사용

import java.io.*;

public class Main {

    public static void main(String[] args) throws IOException {
        int[] arr = new int[2000001];

        BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
        StringBuilder sb = new StringBuilder();

        int N = Integer.parseInt(bf.readLine());
        for (int i = 0; i < N; i++) {
            arr[Integer.parseInt(bf.readLine()) + 1000000 ] = 1;
        }

        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == 1) {
                sb.append(i - 1000000).append('\n');
            }
        }
        System.out.println(sb);
    }
}

배열의 길이를 1,000,000 이 아니고 2,000,000으로 해놓는 이유는 -1,000,000을 입력 받았을 경우에 arr[0] 값에 체크 해놨다가 

다시 출력할때, 0 - 1,000,000를 해주면 처음 입력 받았던 -1,000,000를 출력을 할 수 있도록 두배로 미리 생성을 해놓았다!

 

 

 

Collections.sort() 를 사용

import java.io.*;
import java.util.ArrayList;
import java.util.Collections;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

        int N = Integer.parseInt(bf.readLine());
        ArrayList<Integer> arrayList = new ArrayList<>();

        for (int i = 0; i < N; i++) {
            arrayList.add(Integer.parseInt(bf.readLine()));
        }

        Collections.sort(arrayList);

        for (Integer integer : arrayList) {
            bw.write(integer + "\n");
        }
        bw.flush();
        bw.close();
    }
}

 

반응형
저작자표시 (새창열림)
  1.  
  2.  
  3. 🚀문제
  4. 💬 예제 입력           
  5. 💬 예제 출력
  6.  
  7.  
  8. 🌈 나의 풀이
  9. Merge Sort 사용
  10. Counting Sort 사용
  11. Collections.sort() 를 사용
iseunghan
iseunghan
꾸준하게 열심히..
iseunghan
iseunghan

공지사항

  • 어제보다 나은 오늘이 되기 위해 🔥
  • 분류 전체보기 (262)
    • 💐 Spring (14)
      • 개념 및 이해 (2)
      • Spring 핵심 기술 (24)
      • Spring REST API (8)
      • Spring MVC, DB 접근 기술 (7)
      • Spring Security (23)
      • Spring in Action (1)
    • 🌻 JAVA (84)
      • 자바 ORM 표준 JPA 프로그래밍 (20)
      • 알고리즘, 자료구조 (13)
      • 디자인 패턴 (7)
      • 정리정리정리 (43)
      • JUnit (1)
    • 🔖 Snippets (3)
      • Javascript (3)
    • ⚙️ Devops (22)
      • ⛏ Git (11)
      • 🐳 Docker (6)
      • 🐧 Linux (3)
      • 🌈 Jenkins (1)
      • 📬 Kafka (1)
    • 💬 ETC.. (4)
      • 💻 macOS (2)
    • 🌧️ ORM (2)
      • JPA (2)
    • 🐍 Python (3)
    • 📚 Databases (15)
      • 오라클로 배우는 데이터베이스 개론과 실습(2판) (3)
      • RealMySQL 8.0 (8)
    • 🔥 Computer Science (5)
      • 📡 네트워크 (5)
    • 🏷️ 협업 (1)
    • 📜 코딩테스트 (38)
      • BAEKJOON\수학 1, 수학 2 (8)
      • BAEKJOON\재귀 (5)
      • BAEKJOON\브루트 포스 (3)
      • BAEKJOON\정렬 (1)
      • BAEKJOON\백트래킹 (5)
      • BAEKJOON\BFS, DFS (6)
      • BAEKJOON\이분탐색 (1)
      • BAEKJOON\다이나믹 프로그래밍 (9)
      • BAEKJOON\그리디 알고리즘 (0)
    • ✨ ISEUNGHAN (1)

인기 글

최근 글

전체
오늘
어제
반응형
hELLO · Designed By 정상우.
iseunghan
백준(Baekjoon) 2751번 : 수 정렬하기 2 (JAVA) 문제 풀이
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.