본문 바로가기

CodingTest

[Python][백준 17822번] 원판돌리기 # https://www.acmicpc.net/problem/17822 # 첫번째 시도 import copy import heapq as hq import sys from functools import reduce from collections import deque, defaultdict sys.stdin = open("input.txt", "rt") sys.setrecursionlimit(1501*1501) N, M, T = map(int, input().split()) board = [[0]*M for _ in range(N+1)] for i in range(N): board[i+1] = deque(list(map(int, input().split()))) for _ in range(T): x, d.. 더보기
[Python][백준 1405번] 미친로봇 # https://www.acmicpc.net/problem/1405 dx = [-1, 1, 0, 0] dy = [0, 0, -1, 1] # 각 가는 경로마다, check 배열 세팅 # path 개념으로, 만약, N 만큼 이동할시 # 해당 path 에 대한 확률을 계산한다. num, E, W, S, N = map(int, input().split()) probs = [float(N/100), float(S/100), float(W/100), float(E/100)] check = [[False]*30 for _ in range(30)] tPaths = 0 def findPath(path, number, x, y): global check, tPaths if number == num: tPaths += p.. 더보기
[C++][백준 12886번] 돌그룹 # https://www.acmicpc.net/problem/12886 ''' 정점 : 돌에 있는 돌의 개수 ( A, B, C ) 간선 : ( A, B, C ) -> ( A``, B``, C`` ) 정점의 개수 : ( 최대값 500 ) ^ 3 ?? 아니다. 한 집단에, 최대 정점이 몇개까지 올 수 있는지를 생각해야 한다 500 499 500 500 998 1 1000 498 1 즉, 한집단에 올 수 있는 정점의 최대개수는 1000 개가 되는 것이다 따라서 , 정점의 최대개수는 1000 ^ 3 너무 크다. 10억이라는 크기 자세히 생각해보면, 3개 집단에 있는, 전체 돌의 개수는 변하지 않는다 500 499 500 500 998 1 1000 498 1 위의 변화 과정에서도, 유일하게 변하지 않.. 더보기
[Python][백준 12886번] 돌그룹 # https://www.acmicpc.net/problem/12886 ''' 정점 : 돌에 있는 돌의 개수 ( A, B, C ) 간선 : ( A, B, C ) -> ( A``, B``, C`` ) 정점의 개수 : ( 최대값 500 ) ^ 3 ?? 아니다. 한 집단에, 최대 정점이 몇개까지 올 수 있는지를 생각해야 한다 500 499 500 500 998 1 1000 498 1 즉, 한집단에 올 수 있는 정점의 최대개수는 1000 개가 되는 것이다 따라서 , 정점의 최대개수는 1000 ^ 3 너무 크다. 10억이라는 크기 자세히 생각해보면, 3개 집단에 있는, 전체 돌의 개수는 변하지 않는다 500 499 500 500 998 1 1000 498 1 위의 변화 과정에서도, 유일하게 변하지 않.. 더보기
[Python][백준 11404번] 플로이드 # https://www.acmicpc.net/problem/11404 import sys import heapq from copy import deepcopy from collections import Counter , deque, defaultdict # 모든 점에서, 다른 모든점까지의 최소 거리 = 플로이드 와샬 n = int(input()) m = int(input()) INT_MAX = int(1e9) dp = [[INT_MAX] * n for _ in range(n)] # 자기 자신으로의 거리 0 for i in range(n): dp[i][i] = 0 for _ in range(m): st,ed,cst = map(int,input().split()) st,ed = st-1,ed-1 if cs.. 더보기
[Python][백준 10830번] 행렬곱셉 # https://www.acmicpc.net/problem/10830 from copy import deepcopy N,B = map(int,input().split()) f_matrix = [list(map(int,input().split())) for _ in range(N)] c_matrix = deepcopy(f_matrix) divided = [] # 시간초과 방지를 위해, 반반씩 곱해가는 원리를 적용해갈 것이다 # 예를 들어, B가 8이라면, 8번 행렬을 곱하는 것이 아니라 # A^1, A^2, A^4, A^8 이런 식으로 곱하는 단계를 간소화 할 것이다 tmp = B # 2로 나눈 몫들을 구해간다 while tmp >= 1 : divided.append(tmp) tmp = tmp // 2 .. 더보기
[Python][백준 2839번] 설탕배달 # https://www.acmicpc.net/problem/2839 # 1. '설탕kg'을 입력받는다. # 2. 봉지개수 변수 count 선언 # 3. while문을 계속 돈다 # 1) 입력받은 '설탕kg'이 5로 정확히 나누어떨어진다면, 그 몫을 count에 더해 출력한다 # 2) 나누어떨어지지 않으면 '설탕kg' -= 3 을 해주고 # 3) count += 1 증가. 왜 ? 3kg 봉지를 하나 사용한 것이므로 # 4) 만약 계속 빼다가 '설탕kg'이 < 0 하다면, 3, 5 kg 의 봉지 조합으로 담을 수 없는 무게이므로 -1 출력 Honey = int(input()) cnt = 0 while True : if ( Honey % 5 == 0 ) : cnt = cnt + ( Honey // 5 ) p.. 더보기
[Python][백준 16389번] 행성연결 # https://www.acmicpc.net/submit/16398/35563479 # 크루스칼 --- N = int(input()) csts = [list(map(int,input().split())) for _ in range(N)] def find_parent(parent,x): if parent[x] != x : parent[x] = find_parent(parent,parent[x]) return parent[x] def union_parent(parent,a,b) : a = find_parent(parent,a) b = find_parent(parent,b) if a > b : parent[a] = b else : parent[b] = a # 부모 세팅 parent = [-1] * N for.. 더보기