几种常用算法的整理和思考分析

一、暴力穷举法

  穷举法简单粗暴,没有什么问题是搞不定的,只要你肯花时间。同时对于小数据量,穷举法就是最优秀的算法。

二、贪心算法

  利用局部最优解当作是问题的答案,只要找到符合条件的其中一种情况, 同时该解并不一定是全局最优解。每一步都将最好的结果保存起来,结合起来作为最终答案。

三、分治算法

  分治算法是将一个大问题,分解为若干的子问题,并且每个子问题之间没有交集,相互独立,所有子问题的答案组合起来构成大问题的解答。分支算法的实现方式采用递归实现。
  例如二分查找、快速排序和归并排序算法: https://blog.csdn.net/zhanghan950523/article/details/106088056.

  1. 二分查找:将问题逐步分为两个子问题,并且子问题将互不相关。搜索的深度为logn
  2. 快速排序:通过递归的方法,将问题分为左右两个待排序子序列,并且子序列之间无关。如图中所示:
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值