学大伟业 Day 2 培训总结
一.dp
动态规划的本质
是一种思想。通过对原问题划分成子问题,寻找子问题之间的联系,通过求解子问题得出原问题的解。与贪心不同的是,动归是深谋远虑,考虑全局最优解;而贪心则目光短浅,只考虑局部最优解。
子问题 对应 状态
子问题之间的联系 对应 状态转移
边界子问题 对应 边界状态(状态转移的边界)
边界子问题:其结果不依赖其他子问题
求解动态规划类题目的要点
定义状态
寻找状态转移方程
边界状态
值得一提的是 动态规划中边界状态是可以由状态定义轻松得出 边界不能忽略。
动态规划的分类
按照常用套路的不同,可以对动态规划进行如下分类:
一维动规
背包动规
区间动规
树形动规
DAG动规
二.搜索
搜索的重点
搜索的实现
剪枝与优化
盲目搜索与启发式搜索
盲目搜索(只是搜索的顺序不同):
深度优先搜索 宽度优先搜索
启发式搜索:
A*算法
dfs
问题
1.深度问题
2.死循环问题
解决方法
1.对深度加以限制
2.记录从初始状态到当前状态的路径
深度优先搜索的性质
一般不能保证找到最优解 当深度限制不合理时,可能找不到解,可以将算法改为可变深度限制
最坏情况时,搜索空间等同于穷举
是一个通用的与问题无关的方法
节省内存,只存储从初始节点到当前节点的路径
bfs
优先扩展深度浅的节点 通常使用一个队列来实现
广度优先搜索的性质
当问题有解时,一定能找到解
当问题为单位耗散值,且问题有解时,一定能找到最优解
方法与问题无关,
效率较低
存储量比较大
迭代加深搜索
解决宽搜内存消耗大和深搜不能保证最优解的问题
分析:
宽搜内存消耗大是由于记录了搜索扩展的节点
深搜不能保证最优解是由于其扩展不是按照代价的顺序扩展的
所以我们需要:
不记录所有扩展节点
按照顺序扩展
解决办法:
枚举最大的代价,用深搜判断是否有解
启发式搜索
在OI中常常也被称为A*搜索
关键在于对当前局面作出预估,判断当前局面到目的局面至少还需要多少步
估价函数:估价函数的好坏决定了A*算法的优劣
学大伟业 Day 2 培训总结的更多相关文章
- 学大伟业 Day 1 培训总结
		第一天培训,讲的基本算法,东西很多.还有些数论,图论,数据结构and some small tricks 一.输入输出技巧 //输入输出技巧 /* scanf.printf:速度快,需要记忆不同数据类 ... 
- 学大伟业 Day 6 培训总结
		今天接着昨天的继续讲数据结构 今天先是 分块 在统计问题中,尤其是序列问题,经常涉及到区间的操作,比如修改一段区间的元素,询问某个区间的元素的信息. 如果每次都对一整个区间的每一个元素进行操作的话,那 ... 
- 学大伟业 Day 5 培训总结
		今天讲数据结构 先从mzx大佬的ppt摘抄一段: 数据结构是计算机存储.组织数据的方式.数据结构是指相互之间存在一种或多种特定关系的数据元素的集合. 通常情况下,精心选择的数据结构可以带来更高的运行或 ... 
- 学大伟业 Day 3 培训总结
		今天讲的字符串: 不多说,直接看题 一.表达式求值 题目大意: 输入一行一个表达式,计算其答案 表达式包含非负整数.加减乘除.括号 两种做法 ·栈 ·表达式树 这里更推荐表达式树,因为栈是先压进去,逆 ... 
- 学大伟业 Day 4 培训总结
		今天讲的全是dp... 不多废话,先看一道经典的模板LIS(最长不下降子序列) 一.LIS 给定一个长度为N的数列,求最长上升子序列 例:1 7 2 8 3 4 答案:1 2 3 4 代码: #inc ... 
- 学大伟业Day1解题报告
		学大伟业Day1解题报告 张炳琪 一. 时间分配 T1:30分钟 T2: 60分钟 T3:100分钟 二.答题情况及错因 T1:100 T2:55 T3 ... 
- 学大伟业 2017 国庆 Day1
		期望得分:100+100+20=220 实际得分:100+100+20=220 (好久没有期望==实际了 ,~\(≧▽≦)/~) 对于 a........a 如果 第1个a 后面出现的第1个b~z 是 ... 
- 2017-10-23学大伟业Day1
		T1 叉叉 题目名称 叉叉 程序文件名 cross 输入文件名 cross.in 输出文件名 cross.out 每个测试点时限 1秒 内存限制 128MB 测试点数目 10 每个测试点分值 10 是 ... 
- 学大伟业 国庆Day2
		期望得分:30+100+0=130 实际得分:30+100+20=150 忍者钩爪 (ninja.pas/c/cpp) [问题描述] 小Q是一名酷爱钩爪的忍者,最喜欢飞檐走壁的感觉,有一天小Q发现一个 ... 
随机推荐
- React之特点及常见用法
			1.什么是React? React是一个用于构建用户界面的JavaScript库.主要用于构建UI,很多人认为Reatc是MVC中的V(视图). React起源于Facebook的内部项目,用来架构I ... 
- spring mvc 外键允许Null
			spring mvc 定义模型外键时允许为Null 新手记录,习惯定义模型时将外键的数据类型为long,基本类型. 这样生成的外键是不允许为Null,但是可以通过设置字段的Column注解,使之允许为 ... 
- Python实现抓取CSDN博客首页文章列表
			1.使用工具: Python3.5 BeautifulSoup 2.抓取网站: csdn首页文章列表 http://blog.csdn.net/ 3.分析网站文章列表代码: 4.实现抓取代码: __a ... 
- File 类 的基本操作
			// File 类(静态类) File 的缺点:只能用来读小文件 (它是一下子全都读进去) //创建一个文件 // File.Create(@"C:\Users\wbrm\Deskto ... 
- Hashtable(哈希表)
			简体字繁体字转化: class Program { static void Main(string[] args) { Hashtable ht = new Hashtable(); ; i < ... 
- Python3.4 获取百度网页源码并保存在本地文件中
			最近学习python 版本 3.4 抓取网页源码并且保存在本地文件中 import urllib.request url='http://www.baidu.com' #上面的url一定要写明确,如果 ... 
- Thrift笔记(二)--Thrift框架分层设计
			thrift架构设计使用了分层设计,类似TCP/IP分层,上次使用下层提供的服务.分层设计在计算机中是一个常用的设计,上层和下层定义好接口或者说协议,下层实现可以随意更换,只要实现好定义的接口和协议就 ... 
- hdu 3642 覆盖3次以上体积
			http://www.cnblogs.com/kane0526/archive/2013/03/06/2947118.html 题目大意:给你n个立方体,求相交区域大于等于三次的体积和. 这题需要前面 ... 
- 在asp.net中如何使用Session
			2.那么在asp.net中到底该怎么使用Session呢? Session对象用于存储从一个用户开始访问某个特定的aspx的页面起,到用户离开为止,特定的用户会话所需要的信息.用户在应用程序的页面切换 ... 
- .NET开源工作流RoadFlow-表单设计-日期时间选择
			在表单中添加一个日期时间选择框: 选择范围:指定一个日期选择范围. 时间:是否允许选择时间. 
