백준

🧩 Problem Solving/[백준]

[백준] 2252 줄세우기 (python 파이썬)

https://www.acmicpc.net/problem/2252 2252번: 줄 세우기 첫째 줄에 N(1 ≤ N ≤ 32,000), M(1 ≤ M ≤ 100,000)이 주어진다. M은 키를 비교한 회수이다. 다음 M개의 줄에는 키를 비교한 두 학생의 번호 A, B가 주어진다. 이는 학생 A가 학생 B의 앞에 서야 한다는 의 www.acmicpc.net 풀이 과정 입력값은 키를 비교한 학생 A와 B의 순서가 M개만큼 주어진다. 바로 이전에 풀었던 ACMCraft와 비슷한 유형인 거 같아 같은 방법으로 해결했다. 위상 정렬만 알면 간단하게 해결 가능하다. from collections import deque import sys input = sys.stdin.readline N, M = map(int,in..

🧩 Problem Solving/[백준]

[백준] 11718 그대로 출력하기 (python 파이썬)

https://www.acmicpc.net/problem/11718 11718번: 그대로 출력하기 입력이 주어진다. 입력은 최대 100줄로 이루어져 있고, 알파벳 소문자, 대문자, 공백, 숫자로만 이루어져 있다. 각 줄은 100글자를 넘지 않으며, 빈 줄은 주어지지 않는다. 또, 각 줄은 공백으로 시 www.acmicpc.net 풀이과정 문제 내용은 간단하다. 입력된 물자열을 그대로 출력해주면 된다. 하지만 입력에 끝을 알려주는 정보가 하나도 없다. 몇 줄이 입력되는지도 모르고 마지막에 개행이나 -1같은 입력값도 없다. 해결 방법은 두가지가 있다. 1. try except 구문 사용 2. sys.stdin.readlines() 사용 이문제에 대한 테스트는 직접 타이핑하다가 ctrl - D를 입력해 EOF..

🧩 Problem Solving/[백준]

[백준] 1005 ACMCraft (python 파이썬)

https://www.acmicpc.net/problem/1005 1005번: ACM Craft 첫째 줄에는 테스트케이스의 개수 T가 주어진다. 각 테스트 케이스는 다음과 같이 주어진다. 첫째 줄에 건물의 개수 N과 건물간의 건설순서 규칙의 총 개수 K이 주어진다. (건물의 번호는 1번부 www.acmicpc.net 풀이 과정 처음에 for 문을 사용해서 풀었다. 예제 기준으로 1 2 3 4처럼 순서대로인 경우는 정답이 맞지만. 3 -> 2 -> 1과 같이 순서가 거꾸로인 경우 답이 틀리게 나온다. 순서를 내가 원하는 대로 정하면 해결이 될 거 같아 방법을 찾아보던 도중 위상 정렬이라는 것을 알았다. 큐를 사용해서 진입 차수가 0인 것들을 그래프에서 pop해주며 정렬해주면 된다. 위 그림을 보면 node..

🧩 Problem Solving/[백준]

[백준] 14499 주사위 굴리기(python 파이썬)

https://www.acmicpc.net/problem/14499 14499번: 주사위 굴리기 첫째 줄에 지도의 세로 크기 N, 가로 크기 M (1 ≤ N, M ≤ 20), 주사위를 놓은 곳의 좌표 x, y(0 ≤ x ≤ N-1, 0 ≤ y ≤ M-1), 그리고 명령의 개수 K (1 ≤ K ≤ 1,000)가 주어진다. 둘째 줄부터 N개의 줄에 지 www.acmicpc.net 풀이 과정 가장 중요한 포인트는 주사위 6면의 정보 저장방법이다. 구조체나 클래스를 생각했지만 그냥 리스트로 해도 될거같아서 6크기의 리스트 선언하여 해결함. 이동은 간단한 함수 4개를 만들어서 주사위 리스트의 값들을 교환 시켰다. temp 임시 변수를 하나 선언해서 쉽게 교환 가능. import sys input = sys.std..

🧩 Problem Solving/[백준]

[백준] 7576 토마토 (python 파이썬)

https://www.acmicpc.net/problem/7576 7576번: 토마토 첫 줄에는 상자의 크기를 나타내는 두 정수 M,N이 주어진다. M은 상자의 가로 칸의 수, N은 상자의 세로 칸의 수를 나타낸다. 단, 2 ≤ M,N ≤ 1,000 이다. 둘째 줄부터는 하나의 상자에 저장된 토마토 www.acmicpc.net 풀이 과정 bfs를 이용해 미로찾기를 풀었던 것과 비슷하다. '2178 - 미로탐색'을 먼저 풀어보는것이 좋다. from collections import deque M, N = map(int,input().split()) dx = [-1, 1, 0, 0] dy = [0, 0, 1, -1] box = [] # 1 익은 토, 0 안익은 토, -1 빈 칸 day = [[0 for _ ..

🧩 Problem Solving/[백준]

[백준] 14502 _연구소 (python 파이썬)

https://www.acmicpc.net/problem/14502 14502번: 연구소 인체에 치명적인 바이러스를 연구하던 연구소에서 바이러스가 유출되었다. 다행히 바이러스는 아직 퍼지지 않았고, 바이러스의 확산을 막기 위해서 연구소에 벽을 세우려고 한다. 연구소는 크 www.acmicpc.net 풀이 과정 풀이는 3파트로 나누어서 풀었다. 1) 벽세우기 2) 바이러스 감염 3) 안전 영역 구하기 상대적으로 생각하기 쉬운 2)바이러스 감염은 dfs나 bfs를 사용하고 1)벽세우기 파트는 입력값에 N과 M이 작은 것을 보고(최대 8) 브루트포스 방법을 사용하기로 결정. 먼저 지도에서 빈공간들의 좌표를 모아 저장한다. 그 후 파이썬의 combinations를 사용하여 벽의 세워지는 모든 경우의 수를 추출한..

제봉아
'백준' 태그의 글 목록 (8 Page)