일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 알고리즘
- Ethereum
- Container
- dockerfile
- AWS
- Network
- RabbitMQ
- 전문가를 위한 파이썬
- function
- Thread
- Refactoring
- rust
- BlockChain
- Python
- 이더리움
- 백준
- 동시성
- Kubernetes
- docker
- 파이썬
- Fast API
- guru
- 러스트
- 플랫폼
- 코어 이더리움 프로그래밍
- BAEKJOON
- IMAGE
- 블록체인
- fluent python
- Algorithm
- Today
- Total
글쓰기 | 방명록 | 관리 |
Victoree's Blog
2110-공유기 설치 본문
Concept & Idea
나무자르기 문제를 내가 직접 풀어냈다는 느낌이 약해서 리뷰를 쓰지 않았다. 이 문제는 이분탐색으로 가장 인접한 두 공유기의 최댓값을 찾는 문제였다. 처음에는 이분탐색으로 설치를 하는 방식을 짜야한다고 생각했고, 어떻게 적절한 위치에 설치를 할지 우선순위를 잡아야하나 고민하였다. 하지만 그 어떤 우선순위에도 확실한 과정이 없어서, 질문검색을 통해 아이디어를 찾았다.
중요한 점은 내가 직접 구간을 설정해서 이 구간이 가능한지 여부를 판단하고, 이분탐색으로 이 구간을 정해나가는 것이다. mid라는 구간만큼 공유기를 설치했을 때, 설치가 가능하면 mid값을 더 키우고 불가능하면 더 줄여서 최적의 값을 이분탐색으로 찾아나가는 것이다. 여기서 가능한지의 여부는 그냥 count를 세면 됬었는데,, 괜히 복잡한 조건을 추가해서 시간초과가 발생한 것 같다.. 파라메트릭 서치에 대해 간단히 공부해보자.
파라메트릭 서치는 바이너리 서치와 비슷하다고 느낄 수 있다. 가장 중요한 것은, 바이너리 서치의 경우 mid값이 일치하는지 여부를 확인하는 것이 매우 중요하다. 파라메트릭 서치에서는 내가 원하는 조건을 가장 만족하는 알맞는 값을 특정한 범위내에서 찾고 싶을 때 그 알맞는 값을 찾을 때 이분탐색이 들어가는 것이다.
최적화 문제(문제의 상황을 만족하는 특정 변수의 최댓값 또는 최솟값)을 결정 문제로 바꾸어 푸는것
Code
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
vector<long long> vec;
int n,c;
long long res=-1;
int main(){
cin>>n>>c;
for(int i=0; i<n; i++){
int a;
cin>>a;
vec.push_back(a);
}
sort(vec.begin(), vec.end());
long long st=0,en=vec[vec.size()-1];
long long mid;
while(st<=en) {
mid = (st+en)/2;
int start=vec[0];
int count=1;
for(int i=1; i<n; i++) {
if(start+mid<=vec[i]) {
count++;
start=vec[i];
}
}
if(count>=c) {
res=max(res,mid);
st=mid+1;
} else {
en=mid-1;
}
}
cout<<res<<endl;
}
Fealing
이 문제를 이분탐색으로 어떻게 해결할까 하다가.. 결국 질문검색에서 아이디어를 얻어서 풀게 되었다. 파라메트릭 서치가 뭔지 모르고 풀었다가 친구의 설명을 듣고 아~ 몰라!했었는데, 다시보니까 이게 또 파라메트릭 서치였다니.. 생각을 좀 더 단순히 해서 간단히 해결할 방법을 찾아야겠다..
'Algorithm > 2019~2020' 카테고리의 다른 글
1300_K번째수 (0) | 2021.04.23 |
---|---|
3020_개똥벌레 (0) | 2021.04.23 |
2169-로봇 조종하기 (0) | 2021.04.23 |
11049-행렬 곱셈 순서 (0) | 2021.04.22 |
1660_캡틴 이다솜 (0) | 2021.04.22 |