转:数据结构里面的贪心算法是什么?

简介: 贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有可能达到目标)的决策,从而希望导致结果是最好或最优的算法。贪心算法不能保证最优解,但在解决问题的某些实例时是有效的,并且是很容易理解和实现的。

贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有可能达到目标)的决策,从而希望导致结果是最好或最优的算法。贪心算法不能保证最优解,但在解决问题的某些实例时是有效的,并且是很容易理解和实现的。

一个经典的贪心算法示例是背包问题。假设你有一个容量为V的背包和n个物品,每个物品都有自己的价值和重量。问题是如何选择物品,使得背包装载的物品总价值最大。

贪心算法的做法是:每次选择价值密度最高的物品(即价值/重量),直到背包装满为止。

这个算法并不能保证最优解,但对于许多实例来说是有效的。

代码示例:
  def knapsack(items, maxWeight):
   items.sort(key=lambda x: x[1]/x[0], reverse=True)
   weight = 0
   value = 0
   for item in items:
   if weight + item[0] <= maxWeight:
   weight += item[0]
   value += item[1]
   else:
   remaining = maxWeight - weight
   value += remaining * (item[1]/item[0])
   break
   return value

  items = [(2,3),(3,4),(4,5),(5,6)]
  maxWeight = 5
  print(knapsack(items, maxWeight))
这个算法的复杂度是O(n log n)。

本文转载自:https://www.vipshare.com/archives/10979

目录
相关文章
|
2天前
|
机器学习/深度学习 存储 算法
【初阶数据结构】算法效率大揭秘 | 时间与空间复杂度的深度剖析
【初阶数据结构】算法效率大揭秘 | 时间与空间复杂度的深度剖析
|
1天前
|
算法 Java 测试技术
数据结构 —— Java自定义代码实现顺序表,包含测试用例以及ArrayList的使用以及相关算法题
文章详细介绍了如何用Java自定义实现一个顺序表类,包括插入、删除、获取数据元素、求数据个数等功能,并对顺序表进行了测试,最后还提及了Java中自带的顺序表实现类ArrayList。
5 0
|
2月前
|
算法
【初阶数据结构】复杂度算法题篇
该方法基于如下的事实:当我们将数组的元素向右移动 k 次后,尾部 kmodn 个元素会移动至数组头部,其余元素向后移动 kmodn 个位置。
20 1
|
2月前
|
机器学习/深度学习 人工智能 算法
【人工智能】线性回归模型:数据结构、算法详解与人工智能应用,附代码实现
线性回归是一种预测性建模技术,它研究的是因变量(目标)和自变量(特征)之间的关系。这种关系可以表示为一个线性方程,其中因变量是自变量的线性组合。
54 2
|
3月前
|
机器学习/深度学习 存储 算法
【数据结构】算法的复杂度
算法的时间复杂度和空间复杂度
57 1
【数据结构】算法的复杂度
|
2月前
|
算法
【初阶数据结构篇】二叉树算法题
二叉树是否对称,即左右子树是否对称.
19 0
|
2月前
|
算法 索引
【初阶数据结构篇】单链表算法题进阶
深拷贝应该正好由 n 个全新节点组成,其中每个新节点的值都设为其对应的原节点的值。
19 0
|
2月前
|
存储 算法
【初阶数据结构篇】顺序表和链表算法题
此题可以先找到中间节点,然后把后半部分逆置,最近前后两部分一一比对,如果节点的值全部相同,则即为回文。
20 0
|
3月前
|
搜索推荐 算法
【数据结构】排序算法——Lesson2
【7月更文挑战第24天】
18 3
|
2月前
|
存储 缓存 算法
深入解析B树:数据结构、存储结构与算法优势
深入解析B树:数据结构、存储结构与算法优势