【软件设计师】下午考试----数据结构及算法应用学习记录

此题难度较高,不建议花太多时间

常见四种算法:分治法、回溯法、贪心法、动态规划法

 


分治法

可以通俗的解释为:把一片领土分解,分解为若干块小部分,然后一块块地占领征服,被分解的可以是不同的政治派别或是其他什么,然后让他们彼此异化。

分治法的精髓:

分--将问题分解为规模更小的子问题;

治--将这些规模更小的子问题逐个击破;

合--将已解决的子问题合并,最终得出“母”问题的解;

回溯法

(探索与回溯法)是一种选优搜索法,又称为试探法,按选优条件向前搜索,以达到目标。但当探索到某一步时,发现原先选择并不优或达不到目标,就退回一步重新选择,这种走不通就退回再走的技术为回溯法,而满足回溯条件的某个状态的点称为“回溯点”。

贪心算法

不是对所有问题都能得到整体最优解,关键是贪心策略的选择,选择的贪心策略必须具备无后效性,即某个状态以前的过程不会影响以后的状态,只与当前状态有关。

动态规划

划分子问题,并把子问题结果使用数组存储,利用查询子问题结果构造最终问题结果。

 

 

你可能感兴趣的:(软件设计师,软件设计师--学习记录)