일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 알고리즘
- 프로그래밍
- 파이썬 강좌
- 자살
- 슬픔
- python 강좌
- 인생
- python 강의
- 철학
- 계획
- 라즈베리파이 모니터
- BOJ
- mmcv
- 다이나믹프로그래밍
- mmdetection
- it
- C++
- 2020
- 파이썬 강의
- 2021
- python
- 백준
- dp
- 파이썬
- dynamic programming
- 공부
- 강좌
- 강의
- 자작시
- 2024
Archives
- Today
- Total
Stargazer
[백준(BOJ)] 11049번 : 행렬 곱셈 순서 C++ 풀이(DP) 본문
Undergraudate basics(학부생 기초)/자료구조, 알고리즘
[백준(BOJ)] 11049번 : 행렬 곱셈 순서 C++ 풀이(DP)
COM2IT 2022. 7. 14. 18:50반응형
접근:
DP(Dynamic Programming)을 이용해서 푸는 문제.
발상은 행렬 곱셈이 이루어진 후에 두 행렬이 하나의 행렬로 이루어지기 때문에 작은 문제를 뭉쳐서 큰 문제를 해결 할 수 있음을 암시한다.
전략:
전체 행렬의 곱을 큰 문제로 보았을 때, 두 행렬의 곱으로 나눌 수 있고(구간 단위로),
이는 작은 문제로 나누어서 해결한다는 뜻이다.
그 행렬을 구할 수 있는 모든 경우의 수 중에 가장 연산이 가장 작으려면, 구간을 어떻게 나누었을 때 가장 곱 연산이 작은 지를 알면된다. 따라서 구간을 잘게 쪼개어 DP적으로 해결한다.
맨 아래(기본 행렬 곱)에 도달 했을 때, 두 행렬의 곱 연산 수를 구하여서 그 값을 저장한다.
이를 쌓아서 올리면 전체 곱셈 순서를 구할 수 있게 된다.
-> 행렬을 나누는 경우의 수를 모두 확인할 때,
DP로 구해낸 이전 결과 값을 이용하여 전 행렬의 연산 수를 구하고, 그 둘의 행렬을 곱할 때의 수를 더한다.
이 값을 확인할 때 모두 확인하고 가장 작은 것을 취해서 dp 배열에 저장한다.
코드:
#include <iostream>
#include <vector>
#define INF INT32_MAX
using namespace std;
int n;
vector<pair<int,int>> matrix;
int dp[501][501];
int make(){
for(int dis = 1; dis < n; dis++){ //행렬의 간격
for(int i = 0 ; i < n - dis;i++){ //행렬 시작 위치
dp[i][i+dis] = INF;
for(int j=i; j <= i + dis ;j++){ //연산 최소값 중간 탐색
dp[i][i+dis] = min(dp[i][i+dis], dp[i][j] + dp[j+1][i+dis] + matrix[i].first *matrix[j].second *matrix[i+dis].second);
}
}
}
return dp[0][n-1];
}
int main(){
cin >> n;
int a,b;
for(int i=0;i<n;i++){
cin >> a >> b;
matrix.push_back({a,b});
}
cout << make() << '\n';
return 0;
}
반응형
'Undergraudate basics(학부생 기초) > 자료구조, 알고리즘' 카테고리의 다른 글
[백준(BOJ)] 2623번 : 음악 프로그램 C++ 풀이(위상정렬) (0) | 2022.07.31 |
---|---|
[백준(BOJ)] 12100번 : 2048(Easy) C++ 풀이(시뮬레이션, DFS) (0) | 2022.07.14 |
[백준(BOJ)] 12015번 : 가장 긴 증가하는 부분 수열 C++ 풀이 (이분 탐색) (0) | 2022.07.13 |
[백준] 9328번 : 열쇠 c++ 풀이(BFS) (0) | 2022.07.12 |
[백준] 9019번 : DSLR (BFS - Queue) (0) | 2022.07.11 |
Comments