[백준 알고리즘] 10989번: 수 정렬하기 3 (파이썬 / Python)
·
알고리즘/백준
문제 N개의 수가 주어졌을 때, 이를 오름차순으로 정렬하는 프로그램을 작성하시오. 입력 첫째 줄에 수의 개수 N(1 ≤ N ≤ 10,000,000)이 주어진다. 둘째 줄부터 N개의 줄에는 수가 주어진다. 이 수는 10,000보다 작거나 같은 자연수이다. 출력 첫째 줄부터 N개의 줄에 오름차순으로 정렬한 결과를 한 줄에 하나씩 출력한다. 예제 입력 10 5 2 3 1 4 2 3 5 1 7 예제 출력 1 1 2 2 3 3 4 5 5 7 문제 접근 N의 개수의 범위가 (1 ≤ N ≤ 10,000,000)이므로, 단순히 정렬을 하면 시간초과가 날 것이다. 10000개의 배열을 만들고 들어오는 값만큼 1씩 해당 인덱스에 더해주면 된다. 정답 코드 import sys n = int(sys.stdin.readline..
[백준 알고리즘] 1920번: 수 찾기 (파이썬 / Python)
·
알고리즘/백준
문제 N개의 정수 A[1], A[2], …, A[N]이 주어져 있을 때, 이 안에 X라는 정수가 존재하는지 알아내는 프로그램을 작성하시오. 입력 첫째 줄에 자연수 N(1 ≤ N ≤ 100,000)이 주어진다. 다음 줄에는 N개의 정수 A[1], A[2], …, A[N]이 주어진다. 다음 줄에는 M(1 ≤ M ≤ 100,000)이 주어진다. 다음 줄에는 M개의 수들이 주어지는데, 이 수들이 A안에 존재하는지 알아내면 된다. 모든 정수의 범위는 -231 보다 크거나 같고 231보다 작다. 출력 M개의 줄에 답을 출력한다. 존재하면 1을, 존재하지 않으면 0을 출력한다. 예제 입력 5 4 1 5 2 3 5 1 3 7 9 5 예제 출력 1 1 0 0 1 문제 접근 가장 쉬운 방법은 두개의 리스트를 만들어 for..
[백준 알고리즘] 18870번: 좌표 압축 (파이썬 / Python)
·
알고리즘/백준
문제 수직선 위에 N개의 좌표 X1, X2, ..., XN이 있다. 이 좌표에 좌표 압축을 적용하려고 한다. Xi를 좌표 압축한 결과 X'i의 값은 Xi > Xj를 만족하는 서로 다른 좌표의 개수와 같아야 한다. X1, X2, ..., XN에 좌표 압축을 적용한 결과 X'1, X'2, ..., X'N를 출력해보자. 입력 첫째 줄에 N이 주어진다. 둘째 줄에는 공백 한 칸으로 구분된 X1, X2, ..., XN이 주어진다. 출력 첫째 줄에 X'1, X'2, ..., X'N을 공백 한 칸으로 구분해서 출력한다. 제한 1 ≤ N ≤ 1,000,000 -109 ≤ Xi ≤ 109 예제 입력 1 5 2 4 -10 4 -9 예제 출력 1 2 3 0 3 1 예제 입력 2 6 1000 999 1000 999 1000 ..
[백준 알고리즘] 1427번: 소트인사이드 (파이썬 / Python)
·
알고리즘/백준
문제 배열을 정렬하는 것은 쉽다. 수가 주어지면, 그 수의 각 자리수를 내림차순으로 정렬해보자. 입력 첫째 줄에 정렬하려고 하는 수 N이 주어진다. N은 1,000,000,000보다 작거나 같은 자연수이다. 출력 첫째 줄에 자리수를 내림차순으로 정렬한 수를 출력한다. 예제 입력 2143 예제 출력 4321 정답 코드 import sys n = sys.stdin.readline().strip() n = list(n) n.sort(reverse=True) print(''.join(n)) sort()의 reverse 파라미터를 이용하고, 출력은 join()을 사용하였다. 1427번: 소트인사이드 첫째 줄에 정렬하려고 하는 수 N이 주어진다. N은 1,000,000,000보다 작거나 같은 자연수이다. www.a..
[백준 알고리즘] 2751번: 수 정렬하기 2 (파이썬 / Python)
·
알고리즘/백준
문제 N개의 수가 주어졌을 때, 이를 오름차순으로 정렬하는 프로그램을 작성하시오. 입력 첫째 줄에 수의 개수 N(1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄부터 N개의 줄에는 수가 주어진다. 이 수는 절댓값이 1,000,000보다 작거나 같은 정수이다. 수는 중복되지 않는다. 출력 첫째 줄부터 N개의 줄에 오름차순으로 정렬한 결과를 한 줄에 하나씩 출력한다. 예제 입력 5 5 4 3 2 1 예제 출력 1 2 3 4 5 정답 코드 import sys n = int(sys.stdin.readline()) a = [] for i in range(n): a.append(int(sys.stdin.readline())) a = sorted(a) for i in range(len(a)): print(a[i..