3180 矩阵连乘
有n个矩阵,大小分别为a[0]∗a[1],a[1]∗a[2],a[2]∗a[3],...,a[n−1]∗a[n],现要将它们依次相乘,只能使用结合率,求最少需要多少次运算。(2<=n<=1000 , a[i]<=100)
两个大小分别为p∗q和q∗r的矩阵相乘时的运算次数计为p∗q∗r。
注意不同的运算顺序会导致运算次数不一样,以样例为例:
如果我们先算前两个矩阵的乘积,将运算1∗10∗5=50次,并得到一个1∗5的矩阵,之后再算这个1∗5的矩阵和最后一个5∗20的矩阵的乘积,将运算1∗5∗20=100次,共运算150次;
如果我们先算后两个矩阵的乘积,将运算10∗5∗20=1000次,并得到一个10∗2010∗20的矩阵,之后再算第一个1∗10的矩阵和这个10∗20的矩阵的乘积,运算1∗10∗20=200次,共运算1200次。
输入
第一行输入一个整数n,表示矩阵的个数。
第二行输入n+1个数,表示给定的矩阵。
输出
输出一个整数,表示最少的运算次数。
数据范围
10% 2 <= n <= 10
30% 2 <= n <= 50
60% 2 <= n <= 100
100% 2 <