一:题目:

输入样例:
在这里给出一组输入。例如:

5
30 35 15 5 10 20

输出样例:
在这里给出相应的输出。例如:

11875

二:基本解析

1.基本的动态规划知识:

1):求解过程是多阶段决策过程,每步处理一个子问题,可用于求解组合优化的问题
含义:通过把复杂的原问题分解为相对简单的的子问题的方法
(2):优化原则:一个最优决策序列的任何子序列本身一定是相对于子序列的初始和结束状态的最优决策序列
(3):动态规划有哪些特征(判断是否是动态规划的关键)
重叠子问题,最优子结构,无后效性
◆重叠子问题:子问题重复出现
◆最优子结构:一个问题的最优解包含其子问题的最优解
◆无后效性:某阶段的状态一旦确定,则此后过程的演变不再受此前各种状态及决策的影响。

(4):动态规划设计要素
1>.问题建模,优化的目标函数是什么?约束条件是什么?
2>.如何划分子问题(边界) ?
3>.问题的优化函数值与子问题的优化函数值存在着什么依赖关系?(递推方程)
4>.是否满足优化原则?
5.>最小子问题怎样界定?其优化函数值,即初值等于什么?

2:关于本题的矩阵乘法和递推方程的得出

3:实例演示

三:思路

思路:这里在考虑的的时候,因为是多个矩阵相乘,求的最小乘法次数,
比如 A1A2A3A4, 那么根据划分的不同,那么其乘法顺序也会不同,继而所求的乘法次数也不一样
划分:((A1
A2)*A3) *A4 等等,那么再求解最小乘法次数的时候,这就涉及到是个
动态的过程
在用 动态划分的思想做的时候,先创建一个二维数组,用来存放不同个数矩阵相乘的
最小乘法次数,然后根据划分 来求得最小的乘法次数

四:上码

/*思路:这里在考虑的的时候,因为是多个矩阵相乘,求的最小乘法次数,比如 A1*A2*A3*A4, 那么根据划分的不同,那么其乘法顺序也会不同,继而所求的乘法次数也不一样划分:((A1*A2)*A3) *A4 等等,那么再求解最小乘法次数的时候,这就涉及到是个动态的过程 在用 动态划分的思想做的时候,先创建一个二维数组,用来存放不同个数矩阵相乘的最小乘法次数,然后根据划分 来求得最小的乘法次数 */#include<bits/stdc++.h>
using namespace std;int N;
int p[1000];
int m[1000][1000];  //m[i][j] 即表示:A(i)A(i+1)(i+2)...A(j); int minimum_num(){//初始化矩阵,一个矩阵乘法次数为0 for(int i = 1; i <= N; i++)m[i][i] = 0;//向二维数组中添加数据,并更新(求最小),for(int i = N; i >= 1; i--){//这里的i 从 N 先开始,不能从1 先开始,因为一旦从1开始  //那么的话 m[1][N],就在第一次循环便求出,那么m[1][N]在划分 //更新的时候,其中的一些值尚未求出来。如果从N开始,那么最后求得是//m[1][N],这样就可以用到了前面已经求出的一些值for(int j = i + 1; j <= N; j++){//任何一个m[i][j],均可这样先表示出来 即从 i 后面开始划分 m[i][j] = m[i][i] + m[i+1][j] + p[i-1]*p[i]*p[j]; //划分更新for(int k = i + 1;k < j; k++){//这里 k = i + 1 ,表示的是从i+1后面开始划分,//因为上方第一次表示出来的时候,就已经是从 i 后面划分了  int temp = m[i][k] + m[k+1][j] + p[i-1] * p[k] * p[j];if(temp < m[i][j]){m[i][j] = temp;}}      }                            } return m[1][N];}int main(){cin >> N;for(int i = 0; i < N + 1; i++){cin >> p[i];}int result = minimum_num();cout << result;}


加油 宝贝!!!!!!!!!!!

7-1 矩阵链相乘问题 (20 分)(思路+详解+题目解析) 动态规划做法相关推荐

  1. 7-16 一元多项式求导 (20 分)(详解+题目分析)

    7-16 一元多项式求导 (20 分) 1:题目 设计函数求一元多项式的导数. 输入格式: 以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. 输出格式: ...

  2. 7-3 凸多边形最优三角剖分 (10 分)(思路+详解+分析题意+动态规划)Come Baby!!!!!!!!!

    一:题目: 给定n边凸多边形P,要求确定该凸多边形的三角剖分(将多边形分割成n-2个三角形),使得该三角剖分中诸三角形上权之和为最小.各边弦的权值以由输入数据给出,以无向图的形式表示.三角形的权值等于 ...

  3. 7-1 银行家算法--安全性检查 (20 分)(思路+详解+知识分析)宝 你今天 AC了吗

    一:前言 停更一周了,在这一周里,我每时每刻都在 想这我这 29个粉丝,庆幸教师资格证终于结束了,贴心杰又可以天天更新博客了 哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈,I am come back; 二: ...

  4. 7-5 流水作业调度 (10 分)(思路+详解+johnson解析)Come Baby!!!!!!!!!!

    一:题目 n个作业{1,2,-,n}要在由2台机器M1和M2组成的流水线上完成加工.每个作业加工的顺序都是先在M1上加工,然后在M2上加工.M1和M2加工作业i所需的时间分别为ai和bi.流水作业调度 ...

  5. 7-32 哥尼斯堡的“七桥问题” (25 分)(思路+详解+题目分析)两种做法任选其一

    一:题目: 哥尼斯堡是位于普累格河上的一座城市,它包含两个岛屿及连接它们的七座桥,如下图所示. 可否走过这样的七座桥,而且每桥只走过一次?瑞士数学家欧拉(Leonhard Euler,1707-178 ...

  6. 7-11 租用游艇问题 (15 分)(思路+详解+一步步分析+网格解决动态规划问题)Come boy!!!!

    一:题目 题目来源:王晓东,<算法设计与分析> 长江游艇俱乐部在长江上设置了n个游艇出租站1,2,-,n.游客可在这些游艇出租站租用游艇,并在下游的任何一个游艇出租站归还游艇.游艇出租站i ...

  7. 1089 狼人杀-简单版 (20 分)-文字详解版

    1089 狼人杀-简单版 (20 分) 题目 以下文字摘自<灵机一动·好玩的数学>:"狼人杀"游戏分为狼人.好人两大阵营.在一局"狼人杀"游戏中,1 ...

  8. 10-1 5-1 查询销售便携式电脑但不销售PC的厂商 (20 分)(分析+详解)

    一:题目 本题目要求编写SQL语句, 查询销售便携式电脑但不销售PC的厂商. 提示:请使用SELECT语句作答. 表结构: CREATE TABLE product ( maker CHAR(20) ...

  9. PAT-2019年冬季考试-甲级-7-1 Good in C (20分)超详解,几招就满分通过

    本题在2021年12月之后才会解封放到免费题库里,目前需要收费. 题目: When your interviewer asks you to write "Hello World" ...

最新文章

  1. 第一个只出现一次的字符位置
  2. 介绍一种导入文件夹中图片数据集的方法
  3. MongoDB的高级语法
  4. Web应用开发中的几个问题
  5. 创建css的时候选择器有哪几类,CSS3-CSS的选择器共有几类?
  6. linux创建sudo用户_Linux终极指南-创建Sudo用户
  7. 前端学习(2511):路径出错
  8. 前端学习(1936)vue之电商管理系统电商系统之再关闭对话框defkeys
  9. 51 nod 1439 互质对(Moblus容斥)
  10. 流媒体协议(二):RTMP协议
  11. 手机h5像素_h5移动端设备像素比dpr介绍
  12. 无法运行regedit.exe的简单解决方法
  13. Material Theme UI 插件的下载安装与使用,免费版Material Theme UI 插件
  14. 数据库连接技术 - 数据库连接池
  15. 富文本转化为普通文本
  16. Linux平台常用终端指令合集【超级全】
  17. 流量消费透明化成为运营商新课题
  18. Windows10设置自动重启或定时重启的方法
  19. java实现后台直接生成二维码图片并直接上传到七牛云上面
  20. 如果你不知道做什么,那就学一门杂学吧

热门文章

  1. Raspkate - 基于.NET的可运行于树莓派的轻量型Web服务器
  2. html overflow 样式,css样式之overflow-x属性样式
  3. 如何在论文中自动生成标准的参考文献格式
  4. 【BIM入门实战】Revit2018项目模板、族库图文安装教程
  5. ArcGIS实验教程——实验三十八:基于ArcGIS的等高线、山体阴影、山顶点提取案例教程
  6. 【ArcGIS风暴】ArcGIS快捷键大全
  7. java.io.File.setExecutable(boolean executable) 方法来设置所有者对于此抽象路径名执行权限。
  8. 我使用 html 反向输出自己打自己(7)
  9. amap vueamap 与_在vue中使用高德地图vue-amap
  10. d类功放芯片_应用于无滤波级D类音频功放的新型死区时间控制系统