알고리즘 정복하기! 64

백준 2217번 Python / Greedy 문제 링크 https://www.acmicpc.net/problem/2217 2217번: 로프 N(1 ≤ N ≤ 100,000)개의 로프가 있다. 이 로프를 이용하여 이런 저런 물체를 들어올릴 수 있다. 각각의 로프는 그 굵기나 길이가 다르기 때문에 들 수 있는 물체의 중량이 서로 다를 수도 있다. 하 www.acmicpc.net 풀이 N = int(input()) ropes = [] answer = [] for _ in range(N): ropes.append(int(input())) ropes.sort(reverse=True) for i in range(N): answer.append(ropes[i]*(i+1)) print(max(answer)) 처음엔 내림차순이 아니라 오름차순으로 정렬한 후, 리스.. 알고리즘 정복하기!/백준 문제풀이 2022. 2. 10.
백준 1026번 Python / Greedy 문제 링크 https://www.acmicpc.net/problem/1026 1026번: 보물 첫째 줄에 N이 주어진다. 둘째 줄에는 A에 있는 N개의 수가 순서대로 주어지고, 셋째 줄에는 B에 있는 수가 순서대로 주어진다. N은 50보다 작거나 같은 자연수이고, A와 B의 각 원소는 100보다 작거 www.acmicpc.net 풀이 N = int(input()) A = list(map(int, input().split())) B = list(map(int, input().split())) A.sort() answer = 0 for i in range(len(A)): max_value = max(B) answer = answer + A[i] * max_value B.remove(max_value) pri.. 알고리즘 정복하기!/백준 문제풀이 2022. 2. 10.
백준 5565번 Python / Math 문제 링크 https://www.acmicpc.net/problem/5565 5565번: 영수증 첫째 줄에 10권의 총 가격이 주어진다. 둘째 줄부터 9개 줄에는 가격을 읽을 수 있는 책 9권의 가격이 주어진다. 책의 가격은 10,000이하인 양의 정수이다. www.acmicpc.net 풀이 total = int(input()) books = [] for _ in range(9): books.append(int(input())) print(total - sum(books)) 전체 가격을 total 변수에 저장한 후 나머지 9개의 가격들은 books라는 리스트에 저장했습니다. 그리고 sum() 함수를 사용해 리스트의 모든 값을 더한 후 전체 가격에서 빼고 출력했습니다. 알고리즘 정복하기!/백준 문제풀이 2022. 2. 10.
백준 10870번 Python / Math 문제 링크 https://www.acmicpc.net/problem/10870 10870번: 피보나치 수 5 피보나치 수는 0과 1로 시작한다. 0번째 피보나치 수는 0이고, 1번째 피보나치 수는 1이다. 그 다음 2번째 부터는 바로 앞 두 피보나치 수의 합이 된다. 이를 식으로 써보면 Fn = Fn-1 + Fn-2 (n ≥ 2)가 www.acmicpc.net 풀이 n = int(input()) def fibo(num): if num 알고리즘 정복하기!/백준 문제풀이 2022. 2. 10.
백준 1712번 Python / Math 문제 링크 https://www.acmicpc.net/problem/1712 1712번: 손익분기점 월드전자는 노트북을 제조하고 판매하는 회사이다. 노트북 판매 대수에 상관없이 매년 임대료, 재산세, 보험료, 급여 등 A만원의 고정 비용이 들며, 한 대의 노트북을 생산하는 데에는 재료비와 www.acmicpc.net 풀이 a, b, c = map(int, input().split()) if b >= c: print(-1) else: print(a//(c-b)+1) 가변 비용(B)이 판매 가격(C) 보다 높으면 아무리 많이 팔아도 수익이 생길 수 없다. 그래서 B >=C 일때는 -1을 출력한다. 문제에서의 식을 A + B*n = C*n (A: 고정 비용, B: 가변 비용, C: 판매비용, n: 판매 수)로.. 알고리즘 정복하기!/백준 문제풀이 2022. 2. 9.
백준 2292번 Python / Math 문제 링크 https://www.acmicpc.net/problem/2292 2292번: 벌집 위의 그림과 같이 육각형으로 이루어진 벌집이 있다. 그림에서 보는 바와 같이 중앙의 방 1부터 시작해서 이웃하는 방에 돌아가면서 1씩 증가하는 번호를 주소로 매길 수 있다. 숫자 N이 주어졌 www.acmicpc.net 풀이 n = int(input()) cnt = 1 multi_six = 6 answer = 1 while n > cnt: answer += 1 cnt += multi_six multi_six += 6 print(answer) 지나가는 방의 횟수가 1번인 수 = 1 (1개) 2번인 수 = 2, 3, 4, 5, 6, 7 (6개) 3번인 수 = 8, 9, 10, 11, 12, 13, 14, 15, 1.. 알고리즘 정복하기!/백준 문제풀이 2022. 2. 9.
백준 1978번 Python / Math 문제 링크 https://www.acmicpc.net/problem/1978 1978번: 소수 찾기 첫 줄에 수의 개수 N이 주어진다. N은 100이하이다. 다음으로 N개의 수가 주어지는데 수는 1,000 이하의 자연수이다. www.acmicpc.net 풀이 n = int(input()) numbers = list(map(int, input().split())) cnt = 0 for i in numbers: state=0 if i > 1: for j in range(2, i): if i % j == 0: state += 1 if state == 0: cnt+=1 print(cnt) - 조건문을 사용하여 문제를 해결했다. - 주어진 수의 n-1까지 순서대로 나누어 한 번이라도 나머지가 0이면 소수가 아닌 .. 알고리즘 정복하기!/백준 문제풀이 2022. 2. 8.
백준 10872번 Python / Math 문제 링크 https://www.acmicpc.net/problem/10872 10872번: 팩토리얼 0보다 크거나 같은 정수 N이 주어진다. 이때, N!을 출력하는 프로그램을 작성하시오. www.acmicpc.net 풀이 n = int(input()) answer=1 for i in range(1,n+1): answer = answer * i print(answer) 알고리즘 정복하기!/백준 문제풀이 2022. 2. 8.