关于算法的知识点

1.设计动态规划算法的主要步骤是怎么的?请简述

(1)找出最优解的性质,并刻画结构特征

(2)递归的定义最优值

(3)自底向上或自顶向下的记忆方式算出最优值

(4)根据最优值得到的信息,构造问题的最优解

2.分治法所能解决的问题一般具有哪几个特征?请简述

(1)该问题的规模缩小到一定程度就可以很容易的解决

(2)该问题可以分解为若干个较小的相同问题

(3)利用该问题分解出的子问题的解可以合并为该问题的解

(4)该问题所分解出的子问题是相互独立的,即子问题之间不包括重复子问题

3.分支限界法的搜索策略是什么?

  搜索策略:在搜索解空间树时,每个活结点只有一次机会成为扩展结点。扩展结点一次性产生其所有儿子结点。在这些儿子结点中,导致不可行解或者导致非最优解的儿子结点被舍弃,其余儿子结点被加入活结点表中。此后,从活结点表中按一定的策略取下一结点成为当前扩展结点,并重复上述结点扩展过程。这个过程一直持续到找到所需的解或活结点表为空为止。

posted @   侠客小飞  阅读(255)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示