반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 오퍼레터
- 13908
- 소프티어
- Docker
- 물채우기
- 성적평가
- incr
- 매개변수탐색
- 기술면접
- 백준
- 연결요소
- 백트래킹
- BOJ
- dfs
- 파라메트릭
- Kafka
- upper_bound
- boj #19237 #어른 상어
- 처우산정
- OFFSET
- msSQL
- 이분탐색
- 퇴사통보
- 처우협의
- softeer
- @P0
- compose
- 경력
- BFS
- 6987
Archives
- Today
- Total
기술 블로그
1756번 피자 굽기 본문
728x90
반응형
https://www.acmicpc.net/problem/1756
dp 다이나믹 이분 탐색 binary search 오큰수 nge 오븐 피자 굽기 boj
예제 1에서
5 6 4 3 6 2 3
이라면, 어차피 5 5 4 3 3 2 2와 같다.
이와 같은 배열을 만들어준다.(내 코드의 p)
그리고 이분 탐색을 통해 현재 q[i]가 들어갈 수 있는 가장 오른쪽(오븐으로 치면 맨 아래)으로 갈 수 있을 때까지 탐색한다.
이때, 주의할 것은 Limit인데 코드를 참고.
그리고 Stack을 이용한 풀이 방법도 있는 것 같다.
아마도 오큰수(NGE)인 것 같다.
https://hsdevelopment.tistory.com/374
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 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 | #include<bits/stdc++.h> using namespace std; #define Max 300003 int n, d, p[Max], q[Max]; int main() { //freopen("C:\\Users\\park7\\Desktop\\buba.in.6", "r", stdin); cin.tie(0); scanf("%d %d", &n, &d); for (int i = 0; i < n; i++) { scanf("%d", &p[i]); if (i) { p[i] = min(p[i], p[i - 1]); } } for (int i = 0; i < d; i++) { scanf("%d", &q[i]); } // Limit는 피자 반죽이 오븐에 들어갔을 때 이후로 그 아래로는 탐색이 불가능하므로 // 이분 탐색에서도 제한을 두었다. // Limit을 n - 1로하면 틀린다. 이유는 Left = mid + 1이 처음부터 계속 실행될 때 n - 2까지만 가버리기 때문이다. // n - 1까지 가려면 Limit는 n이 되어야한다. /* Limit이 n - 1에 대한 반례 3 3 1 2 3 1 1 1 correct : 1 wrong : 0 */ int Limit = n, answer = 0; for (int i = 0; i < d; i++) { int Left = 0, Right = n - 1, Search = q[i], pivot = 0; while (Left <= Right) { int mid = (Left + Right) / 2; if (p[mid] >= Search && mid < Limit) { if (pivot < mid) { pivot = mid; } Left = mid + 1; } else { Right = mid - 1; } } // 아직 끝까지 안 갔음에도 불구하고, pivot이 0이라면 if (i < d - 1 && pivot == 0) { printf("0\n"); return 0; } // 끝까지 갔고, pivot이 0이라면 p의 첫 번째 원소와 q의 마지막 원소만 비교하면 된다. // 끝까지 왔다는 것은 위의 if문에서 걸리지 않았다는 뜻이고, 그 전까지는 모두 들어갔다는 뜻. else if (i == d - 1 && pivot == 0) { if (p[0] < q[i]) { printf("0\n"); return 0; } } Limit = pivot; answer = pivot + 1; } printf("%d\n", answer); return 0; } | cs |
728x90
반응형
'알고리즘 문제 > BOJ' 카테고리의 다른 글
18808번 스티커 붙이기 (0) | 2020.03.23 |
---|---|
2482번 색상환 (1) | 2020.03.21 |
7579번 앱 (0) | 2020.03.19 |
1866번 택배 (0) | 2020.03.18 |
3079번 입국심사 (0) | 2020.03.17 |