백준(188)
-
백준 10816번 파이썬 언패킹
백준 10816 - 숫자 카드 2 문제 https://www.acmicpc.net/problem/10816 10816번: 숫자 카드 2 첫째 줄에 상근이가 가지고 있는 숫자 카드의 개수 N(1 ≤ N ≤ 500,000)이 주어진다. 둘째 줄에는 숫자 카드에 적혀있는 정수가 주어진다. 숫자 카드에 적혀있는 수는 -10,000,000보다 크거나 같고, 10,0 www.acmicpc.net 답안 코드 : N = int(input()) N_L = [*map(int, input().split())] M = int(input()) M_L = [*map(int, input().split())] count = {} # 빈 딕셔너리인 count를 초기화 for num in N_L: if num in count: coun..
2024.04.17 -
백준 7785 파이썬 items() 함수 lambda
백준 7785 - 회사에 있는 사람 문제 https://www.acmicpc.net/problem/7785 7785번: 회사에 있는 사람 첫째 줄에 로그에 기록된 출입 기록의 수 n이 주어진다. (2 ≤ n ≤ 106) 다음 n개의 줄에는 출입 기록이 순서대로 주어지며, 각 사람의 이름이 주어지고 "enter"나 "leave"가 주어진다. "enter"인 경우는 www.acmicpc.net 답안 코드 : n = int(input()) logs = [] for _ in range(n): logs.append(input().split()) # 출입 기록을 저장할 딕셔너리 status = {} # 출입 기록 처리 for log in logs: name, action = log[0], log[1] if acti..
2024.04.16 -
백준 14425 파이썬
백준 14425 - 문자열집합 문제 https://www.acmicpc.net/problem/14425 14425번: 문자열 집합 첫째 줄에 문자열의 개수 N과 M (1 ≤ N ≤ 10,000, 1 ≤ M ≤ 10,000)이 주어진다. 다음 N개의 줄에는 집합 S에 포함되어 있는 문자열들이 주어진다. 다음 M개의 줄에는 검사해야 하는 문자열들이 주어 www.acmicpc.net 답안 코드 : N, M = map(int, input().split()) # 집합 S 초기화 S = set() for _ in range(N): string = input() S.add(string) # 검사해야 하는 문자열 입력 및 검사 count = 0 for _ in range(M): test_string = input() ..
2024.04.15 -
백준 10815 파이썬
백준 10815 - 숫자 카드 문제 https://www.acmicpc.net/problem/10815 10815번: 숫자 카드 첫째 줄에 상근이가 가지고 있는 숫자 카드의 개수 N(1 ≤ N ≤ 500,000)이 주어진다. 둘째 줄에는 숫자 카드에 적혀있는 정수가 주어진다. 숫자 카드에 적혀있는 수는 -10,000,000보다 크거나 같고, 10, www.acmicpc.net 답안 코드 : import sys input = sys.stdin.readline # 입력 받기 n = int(input()) # 상근이가 가지고 있는 숫자 카드의 개수 cards = set(map(int, input().split())) # 숫자 카드에 적혀있는 정수들 m = int(input()) # 검사할 숫자의 개수 numb..
2024.04.14 -
백준 18870 파이썬 딕셔너리
백준 18870 - 좌표 압축 문제 https://www.acmicpc.net/problem/18870 18870번: 좌표 압축 수직선 위에 N개의 좌표 X1, X2, ..., XN이 있다. 이 좌표에 좌표 압축을 적용하려고 한다. Xi를 좌표 압축한 결과 X'i의 값은 Xi > Xj를 만족하는 서로 다른 좌표 Xj의 개수와 같아야 한다. X1, X2, ..., XN에 www.acmicpc.net 답안 코드 : import sys input = sys.stdin.readline n = int(input()) arr = list(map(int, input().split())) sorted_arr = sorted(list(set(arr))) # 중복 제거 및 정렬 dic = {sorted_arr[i]: i ..
2024.04.13 -
백준 10814 파이썬 런타임에러 해결
백준 10814 - 나이순 정렬 문제 https://www.acmicpc.net/problem/10814 10814번: 나이순 정렬 온라인 저지에 가입한 사람들의 나이와 이름이 가입한 순서대로 주어진다. 이때, 회원들을 나이가 증가하는 순으로, 나이가 같으면 먼저 가입한 사람이 앞에 오는 순서로 정렬하는 프로그램을 www.acmicpc.net 답안 코드 : # 회원 수 입력 N = int(input()) # 회원 정보 입력 및 리스트에 저장 members = [] for i in range(N): age, name = input().split() members.append((int(age), name, i)) # 나이가 증가하는 순으로 정렬, 나이가 같으면 가입한 순으로 정렬 members.sort(ke..
2024.04.12 -
백준 1181 파이썬 .strip()와 lambda
백준 1181 - 단어 정렬 문제 https://www.acmicpc.net/problem/1181 1181번: 단어 정렬 첫째 줄에 단어의 개수 N이 주어진다. (1 ≤ N ≤ 20,000) 둘째 줄부터 N개의 줄에 걸쳐 알파벳 소문자로 이루어진 단어가 한 줄에 하나씩 주어진다. 주어지는 문자열의 길이는 50을 넘지 않는다. www.acmicpc.net 답안 코드 : N = int(input()) words = [] for _ in range(N): word = input().strip() words.append(word) # 중복 제거 후 길이가 짧은 순서대로, 길이가 같으면 사전 순으로 정렬 sorted_words = sorted(set(words), key=lambda x: (len(x), x))..
2024.04.11 -
백준 11651 파이썬
백준 11651 - 좌표 정렬하기 2 문제 https://www.acmicpc.net/problem/11651 11651번: 좌표 정렬하기 2 첫째 줄에 점의 개수 N (1 ≤ N ≤ 100,000)이 주어진다. 둘째 줄부터 N개의 줄에는 i번점의 위치 xi와 yi가 주어진다. (-100,000 ≤ xi, yi ≤ 100,000) 좌표는 항상 정수이고, 위치가 같은 두 점은 없다. www.acmicpc.net 답안 코드 : n = int(input()) points = [] for _ in range(n): x, y = map(int, input().split()) points.append((x, y)) # 정렬하기 points.sort(key=lambda point: (point[1], point[0]..
2024.04.10 -
백준 11650 파이썬 lambda
백준 11650 - 좌표 정렬하기 문제 https://www.acmicpc.net/problem/11650 11650번: 좌표 정렬하기 첫째 줄에 점의 개수 N (1 ≤ N ≤ 100,000)이 주어진다. 둘째 줄부터 N개의 줄에는 i번점의 위치 xi와 yi가 주어진다. (-100,000 ≤ xi, yi ≤ 100,000) 좌표는 항상 정수이고, 위치가 같은 두 점은 없다. www.acmicpc.net 답안 코드 : n = int(input()) points = [] for _ in range(n): x, y = map(int, input().split()) points.append((x, y)) # 정렬하기 points.sort(key=lambda point: (point[0], point[1])) f..
2024.04.09 -
백준 1427 파이썬 예시
백준 1427 - 소트인사이드 문제 https://www.acmicpc.net/problem/1427 1427번: 소트인사이드 첫째 줄에 정렬하려고 하는 수 N이 주어진다. N은 1,000,000,000보다 작거나 같은 자연수이다. www.acmicpc.net 답안 코드 : N = input() digits = [int(digit) for digit in str(N)] sorted_digits = sorted(digits, reverse=True) # 정렬된 자리수를 합쳐서 결과 출력 result = int("".join(map(str, sorted_digits))) # 문자열들을join함수를 사용하여 하나의 문자열로 print(result) 백준 / 문제 / 단계별로 풀어보기 / 13단계 정렬 생각 :..
2024.04.08