[python] 백준 - 이항 계수 2
·
파이썬/백준
문제 www.acmicpc.net/problem/11051 11051번: 이항 계수 2 첫째 줄에 \(N\)과 \(K\)가 주어진다. (1 ≤ \(N\) ≤ 1,000, 0 ≤ \(K\) ≤ \(N\)) www.acmicpc.net 문제풀이 이항계수는 파스칼의삼각형 모양으로 나온다. 이것을 이용하여 문제를 해결할 수 있다. 먼저 파스칼의 삼각형에 맞게 점화식을 세워 준다. 그다음 각행의 맨처음과 마지막은 1로 채우고 중간 부분은 dp[i][j] = dp[i-1][j-1] + dp[i-1][j] 로 채워주면된다. 코드 # 이항계수 2 n, k = map(int, input().split()) dp = [[0] * 1 for i in range(1002)] dp[1].append(1) for i in ran..
[python] 백준 - 쉬운 계단수
·
파이썬/백준
문제 www.acmicpc.net/problem/10844 10844번: 쉬운 계단 수 첫째 줄에 정답을 1,000,000,000으로 나눈 나머지를 출력한다. www.acmicpc.net 문제 풀이 계단수는 인접한 모든 자리수의 차이가 1이 나기때문에 점화식을 다음과 같이 세움 j == 0 일때 -> dp[j] = dp[j+1] j = (1~8) -> dp[j] = dp[j-1] + dp[j+1] j = 9 -> dp[j] = dp[j-1] 그리고 각 연산 수행시 % 연산도 함께 수행. 코드 # 쉬운 계단수 n = int(input()) dp = [0] * 10 dp_prev = [0]*10 for i in range(1,10): dp[i] = 1 for i in range(1,n): dp_prev = ..
[python] 백준 - 설탕배달
·
파이썬/백준
문제 www.acmicpc.net/problem/2839 2839번: 설탕 배달 상근이는 요즘 설탕공장에서 설탕을 배달하고 있다. 상근이는 지금 사탕가게에 설탕을 정확하게 N킬로그램을 배달해야 한다. 설탕공장에서 만드는 설탕은 봉지에 담겨져 있다. 봉지는 3킬로그 www.acmicpc.net 문제 풀이 sugar 리스트를 만들어 dp로 문제해결. 먼저 5킬로그램 봉지를 사용할 수 있는 경우의 수를 계산하고 (1) dp [i] = dp[i-3] +1 의 점화식을 사용하여 문제해결 (2) 코드 # 설탕배달 n = int(input()) sugar = [int(1e9)]*(n+1) # 5킬로그램 봉지 먼저 사용하는 경우의 수 계산 for i in range(3,n+1): if i % 5 ==0: sugar[i..
[python] 백준 - 분수 찾기
·
파이썬/백준
문제 www.acmicpc.net/problem/1193 1193번: 분수찾기 첫째 줄에 X(1 ≤ X ≤ 10,000,000)가 주어진다. www.acmicpc.net 문제풀이 대각선으로 홀수(n) 번째 줄의 경우 숫자가 3/1 -> 2/2 -> 1/3 이런식으로 분자가 n부터 시작해서 1로 작아지고 분모는 1부터 시작해서 n으로 커진다. 대각선으로 짝수(n) 번째 줄의 경우 숫자가 1/4 -> 2/3 -> 3/2 -> 4/1 이런식으로 분자가 1에서 n으로 커지고 분모는 n에서 1로 작아진다. 코드 n = int(input()) i = 1 total = 1 while total < n: i +=1 total +=i # 짝수번째 줄 : 분자 오름차순 ,분모 내림차순 if i % 2== 0: cnt = ..
[python] 백준 - 더하기 사이클
·
파이썬/백준
문제 www.acmicpc.net/problem/1110 1110번: 더하기 사이클 0보다 크거나 같고, 99보다 작거나 같은 정수가 주어질 때 다음과 같은 연산을 할 수 있다. 먼저 주어진 수가 10보다 작다면 앞에 0을 붙여 두 자리 수로 만들고, 각 자리의 숫자를 더한다. 그 다음, www.acmicpc.net 코드 n = input() target = int(n) cnt = 1 while True: # 한자리수 0을 붙여준다 if len(n) ==1 : n = '0'+n # 더하기 사이클 식 # eval () 함수는 '1+1' 과 같은 문자열을 계산해준다. # eval(1+1) -> 2 # 주어진 수의 가장 오른쪽 자리 수와 앞에서 구한 합의 가장 오른쪽 자리 수를 이어 붙이는작업 n = n[1]..
[python] 백준 - ACM호텔
·
파이썬/백준
문제 www.acmicpc.net/problem/1025 10250번: ACM 호텔 프로그램은 표준 입력에서 입력 데이터를 받는다. 프로그램의 입력은 T 개의 테스트 데이터로 이루어져 있는데 T 는 입력의 맨 첫 줄에 주어진다. 각 테스트 데이터는 한 행으로서 H, W, N, 세 정수 www.acmicpc.net 코드 # 먼저 1층부터 H층까지 각 층의 1호에 손님을 배치 # 101 -> 201 -> 301 ->...-> h01 # 그리고 각 층의 2호에 손님을 배치.. 반복 # zfill()을 이용하여 101 호에서 1 '01' 을 맞춰준다. n = int(input()) for _ in range(n): H,W,N = map(int,input().split()) F = 1 # 각층의 앞쪽부터 손님을 ..
ariz1623
코딩의 숲