noip基础算法贪心和分治最新完整版本.pptVIP

noip基础算法贪心和分治最新完整版本.ppt

  1. 1、本文档共94页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

NOIP基础算法——分治与贪心重庆巴蜀中学黄新军一、分治思想分治法,又叫分治策略,顾名思义,分而治之。它的基本思想:对于难以直接解决的规模较大的问题,把它分解成若干个能直接解决的相互独立的子问题,递归求出各子问题的解,再合并子问题的解,得到原问题的解。通过减少问题的规模,逐步求解,能够明显降低解决问题的复杂度。二、分治法的适用条件能使用分治法解决的问题,它们一般具备以下几个特征:①该问题可分解成若干相互独立、规模较小的相同子问题;②子问题缩小到一定的程度就能轻易得到解;③子问题的解合并后,能得到原问题的解;分治法在信息学竞赛中应用非常广泛,使用分治策略能生成一些常用的算法和数据结构,如快排、最优二叉树、线段树等;还可以直接使用分治策略,解决一些规模很大、无法直接下手的问题。三、分治的三步骤①分解:将要解决的问题分解成若干个规模较小的同类子问题;②解决:当子问题划分得足够小时,求解出子问题的解。③合并:将子问题的解逐层合并成原问题的解。在划分问题时,可以采用递归策略,把一个大问题逐步分解成规模较小的子问题,直至可以直接求出子问题的解;再将子问题逐层合并,返回到顶层,得到原问题的解。根据分治策略的划分原则,把原问题划分成多少个子问题才合适呢?各个子问题的规模应该多大才合适呢?一般来说,每次划分成2个子问题,每个子问题的规模差不多最合适。合并解时要因题而异,有些问题递归分解完能直接得到原问题的解,有些问题需逐层合并,得到原问题的解。四、分治的框架结构五、分治的典型应用1、求最大值和最小值2、求方程的根3、二分查找4、归并排序5、快速幂6、求解线性递推关系7、棋盘覆盖问题8、循环日程表问题9、寻找最近点对1、求最大值和最小值例题1:给n个数,求它们之中最大值和最小值,要求比较次数尽量小。【方法2】分治策略划分:把n个数均分为两半。即:划分点为d=(r1+r2)/2,两个区间为[r1,d]和[d+1,r2]。递归求解:求左半的最小值min1和最大值max1以及右半最小值min2和最大值max2。合并:max1与max2比较得到所有数的最大值为maxx;min1与min2比较得到所有数的最小值为minn。2、求方程的根分析如果精确到小数点后两位,可用简单枚举法:将x从-100.00到100.00(步长0.01)逐一枚举,得到20000个f(x),取其值与0最接近的三个f(x),对应的x即为答案。而题目已改成精度为小数点后4位,枚举算法时间复杂度将达不到要求。直接使用求根公式,极为复杂。加上本题的提示给我们以启迪:采用二分法逐渐缩小根的范围,从而得到根的某精度的数值。分析A.当已知区间(a,b)内有一个根时;用二分法求根,若区间(a,b)内有根,则必有f(a)*f(b)0。重复执行如下的过程:①、若a+0.00001b或f((a+b)/2)=0,则可确定根为(a+b)/2并退出过程;②、若f(a)*f((a+b)/2)0,则由题目给出的定理可知根在区间(a,(a+b)/2)中,故对区间重复该过程;③、若f(a)*f((a+b)/2)0,则必然有f((a+b)/2)*f(b)0,根在((a+b)/2,b)中,对此区间重复该过程。执行完毕,就可以得到精确到0.0001的根。分析B、求方程的所有三个实根所有的根的范围都在-100至100之间,且根与根之差的绝对值=1。因此可知:在[-100,-99]、[-99,-98]、……、[99,100]、[100,100]这201个区间内,每个区间内至多只能有一个根。即:除区间[100,100]外,其余区间[a,a+1],只有当f(a)=0或f(a)*f(a+1)0时,方程在此区间内才有解。若f(a)=0,解即为a;若f(a)*f(a+1)0,则可以利用A中所述的二分法迅速出找出解。如此可求出方程的所有的解。核心参考代码3、归并排序归并排序的基本思想:归并排序充分应用分治算法的策略,通过二分的思想,将n个数最终分成n个单独的有序数列,每个数列中仅有一个数字;再将相邻的两列数据合并成一个有序数列;再重复上面的合并操作,直到合成一个有序数列。按照分治三步法来说:(1)划分:把序列分成元素个数相等的两半;(2)递归求解:把两半分别排序;(3)合并:把两个有序表合成一个有序表;分析显然,前两部分是很容易完成的,关键在于如何把两个有序表合成一个。每次只需要把两个有序表中当前的最小元素加以比较,删除较小元素并加入合并后的新表中。核心参考代码【变形1】求逆序对数目例题3:求“逆序对”给定一

文档评论(0)

xie_tan + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档