코딩 테스트/Baekjoon
백준 온라인 져지 문제 중 풀이해본 문제들의 해결 과정과 코드를 공유하는 내용을 담습니다.
-
문제 보기 : 1182번: 부분수열의 합 문제정답률 : 43%작성 코드def combinations(n,new,c): answer = [] if len(new)==n: return [new] for i in range(c,len(arr)): answer.extend(combinations(n,new+[arr[i]],i+1)) return answern,goal = map(int,input().split())arr = list(map(int,input().split()))arr.sort()visited = [False]*nanswer = []for i in range(1,n+1): answer.extend(combinations(i,[],0))ls = ..
S2 1182. 부분수열의 합문제 보기 : 1182번: 부분수열의 합 문제정답률 : 43%작성 코드def combinations(n,new,c): answer = [] if len(new)==n: return [new] for i in range(c,len(arr)): answer.extend(combinations(n,new+[arr[i]],i+1)) return answern,goal = map(int,input().split())arr = list(map(int,input().split()))arr.sort()visited = [False]*nanswer = []for i in range(1,n+1): answer.extend(combinations(i,[],0))ls = ..
2024.11.22 -
문제 보기 : 10026번: 적록색약 문제정답률 : 56%작성 코드T = int(input())graph = [list(input()) for _ in range(T)]direction = [(-1,0),(1,0),(0,-1),(0,1)]visited_normal = [[-1]*T for _ in range(T)]visited_abnormal = [[-1]*T for _ in range(T)]from collections import dequedef normal(graph,start,visited,p): visited[start[0]][start[1]]=p dd = deque([start]) while dd: x,y = dd.popleft() for dx,dy ..
G5 10026. 적록색약문제 보기 : 10026번: 적록색약 문제정답률 : 56%작성 코드T = int(input())graph = [list(input()) for _ in range(T)]direction = [(-1,0),(1,0),(0,-1),(0,1)]visited_normal = [[-1]*T for _ in range(T)]visited_abnormal = [[-1]*T for _ in range(T)]from collections import dequedef normal(graph,start,visited,p): visited[start[0]][start[1]]=p dd = deque([start]) while dd: x,y = dd.popleft() for dx,dy ..
2024.11.19 -
문제 보기 : 11279번: 최대 힙 문제정답률 : 49%작성 코드import heapq, sysinput = sys.stdin.readlinek = int(input())h = []heapq.heapify(h)for _ in range(k): num = int(input()) if num == 0 and not h: print(0) elif num == 0 and h: heapq.heappush(h,-num) a = -heapq.heappop(h) print(a) else: heapq.heappush(h,-num)풀이입력량이 많기 때문에 sys로 데이터를 한번에 읽어올 수 있도록 처리했고,heapq는 최소값을 출력하는..
S2 11279. 최대 힙문제 보기 : 11279번: 최대 힙 문제정답률 : 49%작성 코드import heapq, sysinput = sys.stdin.readlinek = int(input())h = []heapq.heapify(h)for _ in range(k): num = int(input()) if num == 0 and not h: print(0) elif num == 0 and h: heapq.heappush(h,-num) a = -heapq.heappop(h) print(a) else: heapq.heappush(h,-num)풀이입력량이 많기 때문에 sys로 데이터를 한번에 읽어올 수 있도록 처리했고,heapq는 최소값을 출력하는..
2024.11.18 -
문제 보기 : 2447번: 별 찍기 - 10 문제정답률 : 55%작성 코드def star(n): if n == 3: return ["***","* *","***"] #아닌 경우, star 세트 만들어두기 stars = star(n//3) answer = [] #윗줄 for s in stars: answer.append(s*3) #중간줄 for s in stars: answer.append(s+' '*(n//3)+s) #아랫줄 for s in stars: answer.append(s*3) return answern = int(input())print('\n'.join(star(n))..
G5 2447. 별 찍기 - 10문제 보기 : 2447번: 별 찍기 - 10 문제정답률 : 55%작성 코드def star(n): if n == 3: return ["***","* *","***"] #아닌 경우, star 세트 만들어두기 stars = star(n//3) answer = [] #윗줄 for s in stars: answer.append(s*3) #중간줄 for s in stars: answer.append(s+' '*(n//3)+s) #아랫줄 for s in stars: answer.append(s*3) return answern = int(input())print('\n'.join(star(n))..
2024.11.17 -
문제 보기 : 18870번: 좌표 압축 문제정답률 : 39%작성 코드T = int(input())ls = list(map(int,input().split()))setls = list(set(ls))setls.sort()dicls = {setls[i]:i for i in range(len(setls))}# print(dicls)for i in ls: print(dicls[i], end=' ')풀이좌표 압축이라고 해서 주어지는 좌표들마다 규칙이 있어서 그 규칙을 찾아야하는줄 알았는데 그건 아니었고, 대소 비교를 기준으로 index를 출력하는 문제였다. 실버2이긴 한데.. 왜 실버2인지는 잘 모르겠는 문제..?
S2 18870. 좌표 압축문제 보기 : 18870번: 좌표 압축 문제정답률 : 39%작성 코드T = int(input())ls = list(map(int,input().split()))setls = list(set(ls))setls.sort()dicls = {setls[i]:i for i in range(len(setls))}# print(dicls)for i in ls: print(dicls[i], end=' ')풀이좌표 압축이라고 해서 주어지는 좌표들마다 규칙이 있어서 그 규칙을 찾아야하는줄 알았는데 그건 아니었고, 대소 비교를 기준으로 index를 출력하는 문제였다. 실버2이긴 한데.. 왜 실버2인지는 잘 모르겠는 문제..?
2024.11.16 -
문제 보기 : 2193번: 이친수 문제정답률 : 41%작성 코드T = int(input())before = {0:0,1:1}n = 1while n 풀이끝이 뭔지를 보는게 중요할 것 같다는 생각을 했다.그래서 길이가 1인 경우부터 5인 경우까지 확인하면서 갯수를 세고 규칙을 찾았다.길이가 1이면, 1 만 가능. 즉, key(끝 숫자)가 0,1인 딕셔너리로 나타내면 {0:0,1:1}길이가 2이면, 10 만 가능. 즉, {0:1,1:0}길이가 3이면, 100 / 101 가능. {0:1,1:1}길이가 4이면, 1000 / 1001 / 1010 가능. {0:2,1:1}길이가 5이면, 10000 / 10001 / 10010 / 10100 / 10101 가능. {0:3,1:2}다음턴 next = {0:0,1:0}에..
S3 2193. 이친수문제 보기 : 2193번: 이친수 문제정답률 : 41%작성 코드T = int(input())before = {0:0,1:1}n = 1while n 풀이끝이 뭔지를 보는게 중요할 것 같다는 생각을 했다.그래서 길이가 1인 경우부터 5인 경우까지 확인하면서 갯수를 세고 규칙을 찾았다.길이가 1이면, 1 만 가능. 즉, key(끝 숫자)가 0,1인 딕셔너리로 나타내면 {0:0,1:1}길이가 2이면, 10 만 가능. 즉, {0:1,1:0}길이가 3이면, 100 / 101 가능. {0:1,1:1}길이가 4이면, 1000 / 1001 / 1010 가능. {0:2,1:1}길이가 5이면, 10000 / 10001 / 10010 / 10100 / 10101 가능. {0:3,1:2}다음턴 next = {0:0,1:0}에..
2024.11.15 -
문제 보기 : 4948번: 베르트랑 공준 문제정답률 : 38%작성 코드n = 123456ls = [False,False]+[True]*(2*n-1)for i in range(2,2*n+1): if ls[i]: for j in range(2*i,2*n+1,i): ls[j]=Falsewhile True: n = int(input()) if n == 0: break count = 0 for j in ls[n+1:2*n+1]: if j: count+=1 print(count)풀이미리 에라토스테네스의 체를 max 크기로 만들어둔 다음 index로 분리한 뒤 True 값을 세서 출력한다.0을 입력하면 wh..
S2 4948. 베르트랑 공준문제 보기 : 4948번: 베르트랑 공준 문제정답률 : 38%작성 코드n = 123456ls = [False,False]+[True]*(2*n-1)for i in range(2,2*n+1): if ls[i]: for j in range(2*i,2*n+1,i): ls[j]=Falsewhile True: n = int(input()) if n == 0: break count = 0 for j in ls[n+1:2*n+1]: if j: count+=1 print(count)풀이미리 에라토스테네스의 체를 max 크기로 만들어둔 다음 index로 분리한 뒤 True 값을 세서 출력한다.0을 입력하면 wh..
2024.11.14 -
문제 보기 : 14888번: 연산자 끼워넣기 문제정답률 : 46%작성 코드n = int(input())ls = list(map(int,input().split()))sssd = list(map(int,input().split()))sd = sum(sssd)visited = [False]*sdarr = [1]*sssd[0]+[2]*sssd[1]+[3]*sssd[2]+[4]*sssd[3]maxc=-1000000000; minc=1000000000def permutations(arr): answer = [] used = [False]*(n-1) def back(new,used): if len(new)==len(arr): answer.append(new[:]) ..
S1 14888. 연산자 끼워넣기문제 보기 : 14888번: 연산자 끼워넣기 문제정답률 : 46%작성 코드n = int(input())ls = list(map(int,input().split()))sssd = list(map(int,input().split()))sd = sum(sssd)visited = [False]*sdarr = [1]*sssd[0]+[2]*sssd[1]+[3]*sssd[2]+[4]*sssd[3]maxc=-1000000000; minc=1000000000def permutations(arr): answer = [] used = [False]*(n-1) def back(new,used): if len(new)==len(arr): answer.append(new[:]) ..
2024.11.12