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
- 다익스트라
- Naver Cloud
- 크루스칼
- dfs
- 누적합
- DP
- 구현
- 구간합
- golang
- SWEA
- 21921
- 백준
- 점수 따먹기
- redis
- 16985
- mst
- NCP
- 11659
- 최소신장트리
- gorilla/mux
- 세그먼트 트리
- 이분 탐색
- mongodb
- 정렬
- 시뮬레이션
- 17503
- 맥주 축제
- BOJ
- c++
- 민준이와 마산 그리고 건우
Archives
- Today
- Total
Gi-Log
백준(BOJ) 11568 민균이의 계략 C++ 풀이 본문
문제 링크: https://www.acmicpc.net/problem/11568
풀이에 이용된 알고리즘 및 개념: LIS, DP, 이진 탐색(?)
어디선가 들어본 부분 증가 수열 문제구나... 주어진 수열의 가장 첫 원소만 있을 때의 LIS, 두번째 원소까지 있을 때의 LIS, 세번째까지 있을 때의 LIS... 뭔가 이전 결과들 중에 지금 확인하고 있는 원소를 하나 추가해주면 될 것 같은데... 등등의 아주 다량의 사고의 흐름이 있었다.
예전부터 이런 문제를 보면 "아 LIS 문제 같은데....."라는 생각을 하게 되어서 이참에 다시 개념 정립을 했다.
LIS에 대한 설명은 다른 분들의 아주 뛰어난 정리 및 설명이 있어서 본인이 참고한 페이지를 첨부한다.
https://shoark7.github.io/programming/algorithm/3-LIS-algorithms
https://jason9319.tistory.com/113
DP와 lower_bound를 이용한 두 가지 코드를 하기에 첨부한다.
개인적으로는 lower_bound 풀이가 조금 더 깔끔?한 것 같고 STL을 활용한다는 점에서 공부할 때 재미있었던 것 같다.
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
|
/* BOJ 11568 민균이의 계략 */
#include <iostream>
#include <functional>
#include <algorithm>
#include <string>
#include <queue>
#include <stack>
#include <cmath>
#include <string.h>
#include <vector>
using namespace std;
typedef long long ll;
int n, arr[1001], dp[1001];
int main()
{
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
freopen("input.txt", "r", stdin);
cin >> n;
for (int i = 1; i <= n; i++)
cin >> arr[i], dp[i] = 1;
int ans = 0;
for (int i = 1; i <= n; i++)
{
for (int j = 1; j < i; j++)
{
if (arr[j] < arr[i])
dp[i] = max(dp[i], dp[j] + 1);
}
ans = max(ans, dp[i]);
}
cout << ans << endl;
return 0;
}
|
cs |
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
|
/* BOJ 11568 민균이의 계략 */
#include <iostream>
#include <functional>
#include <algorithm>
#include <string>
#include <queue>
#include <stack>
#include <cmath>
#include <string.h>
#include <vector>
using namespace std;
typedef long long ll;
int n, arr[1001];
int main()
{
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
//freopen("input.txt", "r", stdin);
cin >> n;
for (int i = 1; i <= n; i++)
cin >> arr[i];
vector<int> ans;
const int INF = 1e9;
ans.push_back(-INF); // 절대적으로 작은 수 하나 삽입
for (int i = 1; i <= n; i++)
{
if (arr[i] > ans.back())
ans.push_back(arr[i]);
else
{
// arr[i]가 들어갈 위치 찾기
vector<int>::iterator it = lower_bound(ans.begin(), ans.end(), arr[i]);
*it = arr[i];
}
}
cout << ans.size() - 1 << endl; // 처음 삽입한 -INF 제거
return 0;
}
|
cs |
'알고리즘 BOJ' 카테고리의 다른 글
백준(BOJ) 16985 Maaaaaaaaaze C++ 풀이 (0) | 2021.08.18 |
---|---|
백준(BOJ) 18223 민준이와 마산 그리고 건우 C++ 풀이 (0) | 2021.08.17 |
백준(BOJ) 17616 등수 찾기 C++ 풀이 (0) | 2021.08.15 |
백준(BOJ) 14676 영우는 사기꾼? C++ 풀이 (0) | 2021.08.14 |
백준(BOJ) 4446 ROT13 C++ 풀이 (0) | 2021.07.18 |
Comments