【DP】poj1651 <矩阵链乘法>

原创 2016年08月28日 22:00:32

Description

The multiplication puzzle is played with a row of cards, each containing a single positive integer. During the move player takes one card out of the row and scores the number of points equal to the product of the number on the card taken and the numbers on the cards on the left and on the right of it. It is not allowed to take out the first and the last card in the row. After the final move, only two cards are left in the row. 

The goal is to take cards in such order as to minimize the total number of scored points. 

For example, if cards in the row contain numbers 10 1 50 20 5, player might take a card with 1, then 20 and 50, scoring 
10*1*50 + 50*20*5 + 10*50*5 = 500+5000+2500 = 8000

If he would take the cards in the opposite order, i.e. 50, then 20, then 1, the score would be 
1*50*20 + 1*20*5 + 10*1*5 = 1000+100+50 = 1150.

Input

The first line of the input contains the number of cards N (3 <= N <= 100). The second line contains N integers in the range from 1 to 100, separated by spaces.

Output

Output must contain a single integer - the minimal score.

Sample Input

6
10 1 50 50 20 5

Sample Output

3650

题意:就是n个数,每次从除去首尾两个数的其他数中选一个数和挨着的两边的数相乘得到一个值,然后每次求的值相加,按照这种方法求解一个最小的值。

思路:肯定会想到暴力,但是时间复杂度是指数级的,肯定会tle。看了看书,发现这是一个很裸的矩阵链乘法的题目,收藏一下此题,在仔细看一下这个算法。


【参考代码】

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define INF 0x3f3f3f3f

int n,a[105],dp[105][105],j,k;

int main()
{
    while(~scanf("%d",&n)) {
        for(int i=1;i<=n;i++) scanf("%d",&a[i]);
        memset(dp,0,sizeof(dp));
        for(int l=2;l<n;l++) {
            for(int i=2;i<=n-l+1;i++) {
                j=i+l-1;
                dp[i][j]=INF;
                for(k=i;k<j;k++)
                dp[i][j]=min(dp[i][j],dp[i][k]+dp[k+1][j]+a[i-1]*a[k]*a[j]);
            }
        }
        printf("%d\n",dp[2][n]);
    }
    return 0;
}





版权声明:弱菜一枚,欢迎指正

最优矩阵链乘(动态规划dp)POJ 1651 Multiplication Puzzle

大体题意: 一个n*m的矩阵由n行m列共n*m排列而成。两个矩阵A和B可以相乘当且仅当A的列数等于B的行数。一个n*m的矩阵乘m*p的矩阵,运算量为n*m*p。 矩阵乘法不满足分配律,但满足结合律...

POJ 1651 - Multiplication Puzzle(区间DP,矩阵链乘三种模版详解)

【题意】题目链接http://poj.org/problem?id=1651 给出n(

POJ 1651 Multiplication Puzzle (区间dp 矩阵连乘)

Multiplication Puzzle Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6275 Acce...

poj2778 DNA Sequence AC自动机 dp 矩阵乘法

poj2778 DNA Sequence 题意:求仅有A G C T不含有k(k
  • yxr0105
  • yxr0105
  • 2016年02月03日 01:02
  • 185

poj 3744 Scout YYF I 概率dp+矩阵乘法

分析: dis(k,v1,v2)函数求到当前位置概率为v1,到当前位置之前一步的概率为v2,前进k步到达位置的概率,然后矩阵加速。 代码: //poj 3744 //sep9 #include ...
  • sepNINE
  • sepNINE
  • 2015年04月24日 23:41
  • 630

poj3744 概率dp+矩阵乘法

题目大意在一条路上有n个地雷,有个SB人按照心情走在这条路上,往前走1步的概率是p,往前走2步的概率是(1-p),求他活着走过这条路的概率。分析很容易想到一种dp方程:f[i]=p*f[i-1]+(1...
  • litble
  • litble
  • 2017年05月23日 13:48
  • 94

poj 2440 DNA (dp|递推|找规律|矩阵乘法)

DNA Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3644   Accepted: 1429 Des...

poj 3744 Scout YYF I (矩阵乘法+概率与期望DP)

Scout YYF I Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8237   Ac...

【POJ2778】AC自动机,DP,矩阵乘法

题意:给出n个字串表示“缺陷基因”,然后让求长度为m的基因(4^m个)中有多少个不带病。 题解:首先建立AC自动机,然后从每个节点开始选“ATGC”有四种往外转移的途径。 如:ACG,C这...
  • Vmurder
  • Vmurder
  • 2014年09月17日 08:13
  • 1082

Poj 3734 Blocks(DP,矩阵乘法优化)

题目链接:poj 3734 这道题用矩阵乘法优化DP。 考虑到直接转移的话,N太大,会TLE。由于转移的方案数,转移的状态很少,所以可以将转移的方案用矩阵来表示。 设dp[i][k]表示涂到第i...
  • SAI_D
  • SAI_D
  • 2015年03月20日 21:24
  • 326
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【DP】poj1651 <矩阵链乘法>
举报原因:
原因补充:

(最多只允许输入30个字)