알고리즘 자료 구조 정렬 이분 탐색 해시를 사용한 집합과 맵 풀이 1. 가지고 있는 숫자 카드를 card 배열에 오름차순으로 정렬한다. 2. card 배열의 원소들을 돌며 숫자가 동일한 카드 번호를 하나로 만들고 card 배열의 원소들의 개수를 cardCnt배열에 저장한다. 우선, cardCnt 배열을 완성시키고 cardCnt 배열의 원소 인덱스를 나타내는 point 변수를 0으로 초기화한다. cardCnt에 1을 넣고 연속되는 동일한 card 번호가 나오는 동안 해당 cardCnt[point]++ 한다. 반복문을 빠져나오면 해당 card 번호의 개수를 다 세아린 것이므로 point++한다. erase와 unique 함수를 통해 동일한 숫자는 한개만 남긴다. 3. lt=0, rt=n-1로 카드의 존재 여..
알고리즘 자료 구조 정렬 이분 탐색 풀이 1. 가지고 있는 숫자 카드를 card 배열에 오름차순으로 정렬한다. 2. 가지고 있는지 구분하기 위해서 lt=0, rt=n-1로 카드의 존재 여부를 표시하는 변수 exist=0으로 초기화한다. 3. mid=(lt+rt)/2하여 card[mid] 값이 확인하고자 하는 숫자와 일치하면 exist 변수를 1로 하고 반복문을 탈출한다. card[mid] 값이 확인하고자 하는 숫자보다 작으면 lt=mid+1로 하여 탐색한다. card[mid] 값이 확인하고자 하는 숫자보다 크면 rt=mid-1로 하여 탐색한다. 이 과정은 lt num; card.push_back(num); } sort(card.begin(), card.end()); cin >> m; for(int i=0..
문제 구하고자 하는 것 K개의 랜선을 잘라 길이가 모두 같은 N개의 랜선을 만들 때, 만들 수 있는 최대 랜선의 길이 조건 랜선을 자르거나 만들 때 손실되는 길이는 없다. 기존의 K개의 랜선으로 N개의 랜선을 만들 수 없는 경우는 없다. 항상 센티미터 단위로 정수길이만큼 자른다. N개보다 많이 만드는 것도 N개를 만드는 것에 포함된다. 변수 범위 K는 1이상 10,000 이하의 정수 N은 1이상 1,000,000 이하의 정수 랜선의 길이는 2^31-1보다 작거나 같은 자연수 접근 길이 별로 몇 개의 랜선이 나오는지 확인하여야 한다. 모든 1부터 가장 긴 랜선의 길이까지 모두 탐색하면? 시간초과가 난다. O(가장 긴 랜선길이) 가장 긴 랜선의 길이는 최대 2^31-1(약 20억) 그리고 랜선의 개수만큼 순..