[BOJ-Code] 1654 - 랜선 자르기

Posted by DHniyeo Blog on December 3, 2024

[문제 링크](https://www.acmicpc.net/problem/1654)

💡 이분 탐색/매개 변수 탐색

Memory: 2060KB Time: 8ms Code Length: 765B
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;

int K, N;
int arr[10000];
int maxV = 0;
void init() {
	cin >> K >> N;
	for (int i = 0; i < K; i++) {
		cin >> arr[i];
		if (maxV < arr[i]) {
			maxV = arr[i];
		}
	}
}
int get_peice(long long length){
	int sum = 0;
	for (int i = 0; i < K; i++) {
		sum += (arr[i] / length);
	}
	return sum;
}
long long solve() {
	long long st = 1;
	long long  en = maxV;
	
	while (st< en) {
		long long  mid = (st + en) / 2;
		int result = get_peice(mid);
		if (result < N) {
			en = mid;
		}
		else if (result >= N) {	// 같을 때 st의 값을 올려줘야함.
			st = mid + 1;
		}
	}
	if (get_peice(st) != N) return st - 1; // result == N 일때
	return st;
}
int main() {
	init();
	cout << solve();
}

이 코드는 사용자로부터 입력을 받아들여 일정 길이의 나무 조각을 잘라내는 문제를 해결하는 프로그램이다. 먼저 init() 함수에서는 사용자로부터 K와 N을 입력받고, K개의 나무 조각의 길이를 배열 arr에 저장하면서 가장 긴 나무 조각의 길이를 maxV에 저장한다.

그 다음 get_peice() 함수는 주어진 길이로 나무 조각을 잘랐을 때 얻을 수 있는 조각의 개수를 계산하여 반환한다.

solve() 함수에서는 이진 탐색을 사용하여 최적의 길이를 찾는다. 초기 범위는 1부터 maxV까지로 설정하고, 이진 탐색을 통해 N개의 조각을 얻을 수 있는 최대 길이를 찾는다.

마지막으로 main() 함수에서 init() 함수를 호출하여 입력을 받고, solve() 함수를 호출하여 최적의 길이를 출력한다.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;

int K, N;
int arr[10000];
int maxV = 0;
void init() {
	cin >> K >> N;
	for (int i = 0; i < K; i++) {
		cin >> arr[i];
		if (maxV < arr[i]) {
			maxV = arr[i];
		}
	}
}
int get_peice(long long length){
	int sum = 0;
	for (int i = 0; i < K; i++) {
		sum += (arr[i] / length);
	}
	return sum;
}
long long solve() {
	long long st = 1;
	long long  en = maxV;
	
	while (st < en) {
		long long  mid = (st + en + 1) / 2;
		int result = get_peice(mid);
		if (result < N) {
			en = mid - 1;
		}
		else if (result >= N) {	// 같을 때 st의 값을 올려줘야함.
			st = mid;
		}
	}
	//if (get_peice(st) != N) return st - 1; // result == N 일때
	return en;
}
int main() {
	init();
	cout << solve();
}

이렇게 생각해 볼 수도 있다.