【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(<=100)个数字,每一个数字有一个权值Ai,求从中抽出除了第一个和最后一个以外的中间的数字的最小费用。抽取的顺序...

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<=10)个长度为d(d<=10)串的长度为L(L<=2*10^9)的串有多少个%100000 题解: 做完感觉之...

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

分析: dis(k,v1,v2)函数求到当前位置概率为v1,到当前位置之前一步的概率为v2,前进k步到达位置的概率,然后矩阵加速。 代码: //poj 3744 //sep9 #include ...

poj3744 概率dp+矩阵乘法

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

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

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

POJ 1651(矩阵连乘)

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

【POj】1651 2955(区间dp)

这两道区间DP都是自己想的,值得写一下题解,区间DP养成ing! 2955题目大意:字符串只有(、)、[、]组成,完整的括号之间不能包含不完整的括号,最后让你算出有多少个合法的括号数。 dp[i]...

POJ 1651 Multiplication Puzzle(区间DP)

http://poj.org/problem?id=1651。 头尾不动。通过从小到大枚举长度枚举区间,然后扩散到整个区间。 dp[i][j]表示从i开始到j的区间的分数最小值。 则长度显然从3...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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