Python贪婪算法

贪婪算法

  • 每步均选择局部的最优解,重复此过程,最终即得到全局的最优解
  • 简而言之就是每步都采用最优解

优点:

  • 简单易行

缺点:

  • 并非在所有情况下都奏效

经典的问题:

  1. 背包问题
  2. 集合覆盖问题

贪婪算法下的近似算法解决集合覆盖问题

states_needed = set(["mt", "wa", "or", "id", "nv", "ut", "ca", "az"])

stations = {}
stations["kone"] = set(["id", "nv", "ut"])
stations["ktwo"] = set(["wa", "id", "mt"])
stations["kthree"] = set(["or", "nv", "ca"])
stations["kfour"] = set(["nv", "ut"])
stations["kfive"] = set(["ca", "az"])
final_stations = set()

while states_needed:

    best_station = None
    states_covered = set()
    for station, states in stations.items():
        covered = states_needed & states
        if len(covered) > len(states_covered):
            best_station = station
            states_covered = covered
    states_needed -= states_covered
    final_stations.add(best_station)

print(final_stations)

原文地址:https://www.cnblogs.com/huang-yc/p/10322363.html

时间: 2024-11-05 22:05:57

Python贪婪算法的相关文章

Python实现的贪婪算法

# 使用Python实现贪婪算法# 集合覆盖问题 # 假设你办了个广播节目,要让全美50个州的听众都收听到.为此,你需要决定在哪些广播台播出.在每个广播台播出都需要支出费用,因此你力图在尽可能少的广播台播出 # 1.创建一个列表,其中包含要覆盖的州 states_needed = set(["mt", "wa", "or", "id", "nv", "ut", "ca"

python正则表达式贪婪算法与非贪婪算法与正则表达式子模式的简单应用

先引入一下百度百科对于正则表达式的概念: 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑. 然后我们来引入一下贪婪算法与非贪婪算法的一个概念: 贪婪算法: 贪婪匹配(默认的):在整个表达式匹配成功的前提下,尽可能多的匹配 表达方式: .* .+ .? ······· 非贪婪算法: 贪婪匹配:在整个表达式匹配成功的前提下,尽可能少的匹配 表达方式: .* ? .+? .?? ··

使用python实现森林算法方法步骤详解

本文和大家分享的是使用python实现森林算法相关内容,一起来看看吧,希望对大家学习python有所帮助. 算法描述 随机森林算法 决策树运行的每一步都涉及到对数据集中的最优**点(best split point)进行贪婪选择(greedy selection). 这个机制使得决策树在没有被剪枝的情况下易产生较高的方差.整合通过提取训练数据库中不同样本(某一问题的不同表现形式)构建的复合树及其生成的预测值能够稳定并降低这样的高方差.这种方法被称作引导**算法(bootstrap aggrega

贪婪算法之兑换硬币及问题所在

问题: 以人民币的硬币为例,假设硬币数量足够多.要求将一定数额的钱兑换成硬币.要求兑换硬币数量最少. 思路说明: 这是用贪婪算法的典型应用.在本例中用python来实现,主要思想是将货币金额除以某硬币单位,然后去整数,即为该硬币的个数:余数则做为向下循环计算的货币金额. 这个算法的问题在于,得出来的结果不一定是最有结果.比如,硬币单位是[1,4,6],如果将8兑换成硬币,按照硬币数量最少原则,应该兑换成为两个4(单位)的硬币,但是,按照本算法,得到的结果是一个6单位和两个1单位的硬币.这也是本算

如何捅破python编程的那层纸之二

# coding:utf-8 """ 贴吧上有人问 定义一个函数,名字为sameSums(aList),alist是一个整形list,函数作用是判断能分成两组,使得两组数字的和相等.若可以择返回值是true,若不可以返回值是false.如下例: sameSums([4, 7, 6, 3]) --> True //4+6 = 10 and 7 + 3 = 10 sameSums([3, 3]) --> True sameSums([4, 12, 16]) -->

简单DNA序列组装(贪婪算法)

生物信息学原理作业第四弹:DNA序列组装(贪婪算法) 原理:生物信息学(孙啸) 大致思想: 1. 找到权值最大的边: 2. 除去以最大权值边的起始顶点为起始顶点的边: 3. 除去以最大权值边为终点为终点的边: 4. 重复上述步骤,得到所有符合条件的边: 5. 拼接得到的边: 6. 加入孤立点(如果有). 附上Python代码,如果有问题我会及时更正(确实不太熟算法) 简单DNA序列组装(贪婪算法) 转载请保留出处! 1 # -*- coding: utf-8 -*- 2 """

如何在Python中从零开始实现随机森林

欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 决策树可能会受到高度变异的影响,使得结果对所使用的特定测试数据而言变得脆弱. 根据您的测试数据样本构建多个模型(称为套袋)可以减少这种差异,但是树本身是高度相关的. 随机森林是套袋(方法)的延伸,除了基于多个测试数据样本构建树木之外,它还限制了可用于构建树木的特征,使得树木间具有差异.这反过来可以提升算法的表现. 在本教程中,您将了解如何在Python中从头开始实现随机森林算法. 完成本教程后,您将知道: 套袋决策树和随机森林算法的区别.

python学习之模块--模块(五)

5.10 包 5.10.1 包的概念 [官网解释] Packages are a way of structuring Python's module namespace by using "dotted module names" 包是一种通过使用'.模块名'来组织python模块名称空间的方式. 具体的:包就是一个包含有__init__.py文件的文件夹,所以其实我们创建包的目的就是为了用文件夹将文件/模块组织起来 [强调]: 在python3中,即使包下没有__init__.py

python中文语料分词处理,按字或者词cut_sentence

cut_sentence.py import string import jieba import jieba.posseg as psg import logging #关闭jieba日制 jieba.setLogLevel(logging.INFO) jieba.load_userdict("./corpus/keywords.txt") stopwords_path = "./corpus/stopwords.txt" stopwords = [i.strip