코딩테스트

문제 1654번: 랜선 자르기 첫째 줄에는 오영식이 이미 가지고 있는 랜선의 개수 K, 그리고 필요한 랜선의 개수 N이 입력된다. K는 1이상 10,000이하의 정수이고, N은 1이상 1,000,000이하의 정수이다. 그리고 항상 K ≦ N 이다. 그 www.acmicpc.net 코드 My answer import sys input=sys.stdin.readline k,n=map(int,input().split()) line=[int(input()) for _ in range(k)] start,end=0,max(line)+1 while(start
오늘은 순서대로가 아니라 코테에서 자주 등장하는 이진(이분)탐색에 대해서 작성해볼 것이다. 이진탐색은 교재 p.186 Chapter 7에서 등장한다. 순차탐색 - 리스트 안에 있는 특정 target을 찾기 위해 앞에서부터 데이터를 하나씩 차례대로 확인 - 보통 정렬되어 있지 않은 데이터에서 target을 찾을 때 사용. - 앞에서부터 데이터를 확인하기 때문에 데이터가 N개일 때 최악의 경우 시간복잡도는 O(N) 이진탐색 - 배열 내부의 데이터가 정렬되어 있어야만 사용할 수 있는 알고리즘. - 정렬이 되어있다면 매우 빠르게 데이터를 찾을 수 있는 알고리즘. - 데이터를 찾기위해 (시작점, 끝점, 중간점)을 이용하여 탐색. - 한번 확인할 때 마다 확인하는 원소의 개수가 절반씩 줄어들기 때문에 시간복잡도가 ..
문제 11663번: 선분 위의 점 첫째 줄에 점의 개수 N과 선분의 개수 M이 주어진다. (1 ≤ N, M ≤ 100,000) 둘째 줄에는 점의 좌표가 주어진다. 두 점이 같은 좌표를 가지는 경우는 없다. 셋째 줄부터 M개의 줄에는 선분의 시작점과 www.acmicpc.net 코드 My answer(시간초과, 메모리 초과) import sys from bisect import bisect_left,bisect_right input=sys.stdin.readline n,m=map(int,input().split()) point=list(map(int,input().split())) # 반복문을 이용한 이진탐색(시간초과) for i in range(m): a,b=list(map(int,input().spli..
문제 2805번: 나무 자르기 첫째 줄에 나무의 수 N과 상근이가 집으로 가져가려고 하는 나무의 길이 M이 주어진다. (1 ≤ N ≤ 1,000,000, 1 ≤ M ≤ 2,000,000,000) 둘째 줄에는 나무의 높이가 주어진다. 나무의 높이의 합은 항상 M보 www.acmicpc.net 코드 My answer import sys from bisect import bisect_left input=sys.stdin.readline n,m=map(int,input().split()) tree=list(map(int,input().split())) def binary_search(start,end): if(start>end): return end mid=(start+end)//2 tmp=[i-mid for ..
📖 문제 오늘 동빈이는 여행 가신 부모님을 대신해서 떡집 일을 하기로 했다. 오늘은 떡볶이 떡을 만드는 날이다. 동빈이네 떡볶이 떡은 재밌게도 떡볶이 떡의 길이가 일정하지 않다. 대신에 한 봉지 안에 들어 가는 떡의 총 길이는 절단기로 잘라서 맞춰준다. 절단기에 높이(H)를 지정하면 줄지어진 떡을 한 번에 절단한다. 높이가 H보다 긴 떡은 H 위의 부분이 잘릴 것이고, 낮은 떡은 잘리지 않는다. 예를 들어 높이가 19, 14, 10, 17cm인 떡이 나란히 있고 절단기 높이를 15cm로 지정하면 자른 뒤 떡의 높이는 15, 14, 10, 15cm가 될 것이다. 잘린 떡의 길이는 차례대로 4, 0, 0, 2cm이다. 손님은 6cm 만큼의 길이를 가져간다. 손님이 왔을 때 요청한 총 길이가 M일 때 적어도 ..
📖문제 동빈이네 전자 매장에는 부품이 N개 있다. 각 부품은 정수 형태의 고유한 번호가 있다. 어느 날 손님이 M개 종류의 부품을 대량으로 구매하겠다며 당일 날 견적서를 요청했다. 동빈이는 때를 놓치지 않고 손님이 문의한 부품 M개 종류를 모두 확인해서 견적서를 작성해야 한다. 이때 가게 안에 부품이 모두 있는지 확인하는 프로그램을 작성해보자. 이때 손님이 요청한 부품 번호의 순서대로 부품을 확인해 부품이 있으면 yes를, 없으면 no를 출력한다. 구분은 공백으로 한다. 입력 조건 첫째 줄에 정수 N이 주어진다. (1
창빵맨
'코딩테스트' 카테고리의 글 목록 (5 Page)