•알고리즘(Algorithm )/문제풀이
[백준2263&파이썬] 분할정복을 이용해 트리의 preorder 구하기
# 문제 백준 2263 트리의 순회 파이썬 풀이 2263번: 트리의 순회 첫째 줄에 n(1 ≤ n ≤ 100,000)이 주어진다. 다음 줄에는 인오더를 나타내는 n개의 자연수가 주어지고, 그 다음 줄에는 같은 식으로 포스트오더가 주어진다. www.acmicpc.net # 코드 import sys sys.setrecursionlimit(100_000) n = int(sys.stdin.readline().strip()) inorders = list(map(int,sys.stdin.readline().split())) postorders = list(map(int,sys.stdin.readline().split())) # 1. postorder를 통해서 ROOT노드를 알 수 있다. # - 맨 끝 노드가 ROO..
[백준11660&파이썬] 누적합을 구하는 기본문제
# 문제 백준 11660 구간 합 구하기 5 파이썬 풀이 11660번: 구간 합 구하기 5 첫째 줄에 표의 크기 N과 합을 구해야 하는 횟수 M이 주어진다. (1 ≤ N ≤ 1024, 1 ≤ M ≤ 100,000) 둘째 줄부터 N개의 줄에는 표에 채워져 있는 수가 1행부터 차례대로 주어진다. 다음 M개의 줄에는 네 www.acmicpc.net # 코드 import sys def print2D(arr) : for i in arr : print(*i) print() N,M = map(int,sys.stdin.readline().split()) board = list() for _ in range(N) : line = list(map(int,sys.stdin.readline().split())) board.a..
[백준1167&파이썬] 트리의 지름을 BFS를 사용해 구하자. 트리는 사이클이 존재하지 않는다.
# 문제 백준 1167 트리의 지름 파이썬 풀이 1167번: 트리의 지름 트리가 입력으로 주어진다. 먼저 첫 번째 줄에서는 트리의 정점의 개수 V가 주어지고 (2 ≤ V ≤ 100,000)둘째 줄부터 V개의 줄에 걸쳐 간선의 정보가 다음과 같이 주어진다. 정점 번호는 1부터 V까지 www.acmicpc.net # 코드 import sys from collections import defaultdict from collections import deque # 정점의 개수 V = int(sys.stdin.readline().strip()) trees = defaultdict(list) for _ in range(V) : line = list(map(int,sys.stdin.readline().split())..
[백준1967&파이썬] 트리의 지름을 다익스트라를 이용해 구하자
# 문제 백준 1967 트리의 지름 파이썬 풀이 1967번: 트리의 지름 파일의 첫 번째 줄은 노드의 개수 n(1 ≤ n ≤ 10,000)이다. 둘째 줄부터 n-1개의 줄에 각 간선에 대한 정보가 들어온다. 간선에 대한 정보는 세 개의 정수로 이루어져 있다. 첫 번째 정수는 간선이 연 www.acmicpc.net # 코드 import sys from collections import defaultdict from heapq import * def print2D(arr) : for i in arr : print(*i) # 노드의 개수 n = int(sys.stdin.readline().strip()) trees = defaultdict(list) distance = [0] * (n+1) visit = [-..
[백준1629&파이썬] 파이썬을 이용해 빠른 거듭제곱 구하기, Fast Computing Power
# 문제 백준 1629 곱셈 파이썬 풀이 1629번: 곱셈 첫째 줄에 A, B, C가 빈 칸을 사이에 두고 순서대로 주어진다. A, B, C는 모두 2,147,483,647 이하의 자연수이다. www.acmicpc.net # 코드 import sys A,B,C = map(int,sys.stdin.readline().split()) # A를 B번곱한수를 C로 나눈값 # O(logN)을 가지는 곱셈법을 사용해서 구해야 한다. def power(a,b) : if b == 0 : return 1 if b % 2 == 0 : # 짝수일때 temp = b//2 result = power(a,temp) % C return result*result else : # 홀수 일때 temp = b//2 result = pow..
[백준17144&파이썬] 시계 또는 반시계 방향으로 배열원소 회전하기 , 탐색 후 일괄업데이트
# 문제 백준 17144 미세먼지 안녕! 파이썬 풀이 17144번: 미세먼지 안녕! 미세먼지를 제거하기 위해 구사과는 공기청정기를 설치하려고 한다. 공기청정기의 성능을 테스트하기 위해 구사과는 집을 크기가 R×C인 격자판으로 나타냈고, 1×1 크기의 칸으로 나눴다. 구사 www.acmicpc.net # 코드 ''' - 동시에 미세먼지 값들을 spread시킨다 - spread시켰다면 공기청정기의 바람에 의해 이동시킨다. ''' import sys from collections import deque def print2D(arr): for i in arr: print(i) # ROW, COL, TIME R, C, T = map(int, sys.stdin.readline().split()) board = li..