=====================================================================
1):求解过程是多阶段决策过程,每步处理一个子问题,可用于求解组合优化的问题
含义:通过把复杂的原问题分解为相对简单的的子问题的方法
(2):优化原则:一个最优决策序列的任何子序列本身一定是相对于子序列的初始和结束状态的最优决策序列
(3):动态规划有哪些特征(判断是否是动态规划的关键)
重叠子问题,最优子结构,无后效性
◆重叠子问题:子问题重复出现
◆最优子结构:一个问题的最优解包含其子问题的最优解
◆无后效性:某阶段的状态一旦确定,则此后过程的演变不再受此前各种状态及决策的影响。
(4):动态规划设计要素
1>.问题建模,优化的目标函数是什么?约束条件是什么?
2>.如何划分子问题(边界) ?
3>.问题的优化函数值与子问题的优化函数值存在着什么依赖关系?(递推方程)
4>.是否满足优化原则?
5.>最小子问题怎样界定?其优化函数值,即初值等于什么?
===================================================================
思路:这里在考虑的的时候,因为是多个矩阵相乘,求的最小乘法次数,
比如 A1_A2_A3_A4, 那么根据划分的不同,那么其乘法顺序也会不同,继而所求的乘法次数也不一样
划分:((A1_A2)*A3) *A4 等等,那么再求解最小乘法次数的时候,这就涉及到是个
动态的过程
在用 动态划分的思想做的时候,先创建一个二维数组,用来存放不同个数矩阵相乘的
最小乘法次数,然后根据划分 来求得最小的乘法次数
===================================================================
/*
思路:这里在考虑的的时候,因为是多个矩阵相乘,求的最小乘法次数,
比如 A1A2A3*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;
}
}
}
最后
小编在这里分享些我自己平时的学习资料,由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!
程序员代码面试指南 IT名企算法与数据结构题目最优解
这是” 本程序员面试宝典!书中对IT名企代码面试各类题目的最优解进行了总结,并提供了相关代码实现。针对当前程序员面试缺乏权威题目汇总这一-痛点, 本书选取将近200道真实出现过的经典代码面试题,帮助广“大程序员的面试准备做到万无一失。 “刷”完本书后,你就是“题王”!
《TCP-IP协议组(第4版)》
本书是介绍TCP/IP协议族的经典图书的最新版本。本书自第1版出版以来,就广受读者欢迎。
本书最新版进行」护元,以体境计算机网络技不的最新发展,全书古有七大部分共30草和7个附录:第一部分介绍一些基本概念和基础底层技术:第二部分介绍网络层协议:第三部分介绍运输层协议;第四部分介绍应用层协议:第五部分介绍下一代协议,即IPv6协议:第六部分介绍网络安全问题:第七部分给出了7个附录。
Java开发手册(嵩山版)
这个不用多说了,阿里的开发手册,每次更新我都会看,这是8月初最新更新的**(嵩山版)**
MySQL 8从入门到精通
本书主要内容包括MySQL的安装与配置、数据库的创建、数据表的创建、数据类型和运算符、MySQL 函数、查询数据、数据表的操作(插入、更新与删除数据)、索引、存储过程和函数、视图、触发器、用户管理、数据备份与还原、MySQL 日志、性能优化、MySQL Repl ication、MySQL Workbench、 MySQL Utilities、 MySQL Proxy、PHP操作MySQL数据库和PDO数据库抽象类库等。最后通过3个综合案例的数据库设计,进步讲述 MySQL在实际工作中的应用。
Spring5高级编程(第5版)
本书涵盖Spring 5的所有内容,如果想要充分利用这一领先的企业级 Java应用程序开发框架的强大功能,本书是最全面的Spring参考和实用指南。
本书第5版涵盖核心的Spring及其与其他领先的Java技术(比如Hibemate JPA 2.Tls、Thymeleaf和WebSocket)的集成。本书的重点是介绍如何使用Java配置类、lambda 表达式、Spring Boot以及反应式编程。同时,将与企业级应用程序开发人员分享一些见解和实际经验,包括远程处理、事务、Web 和表示层,等等。
JAVA核心知识点+1000道 互联网Java工程师面试题
企业IT架构转型之道 阿里巴巴中台战略思想与架构实战
本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。
相关阅读docs.qq.com/doc/DSmxTbFJ1cmN1R2dB