【第六天】零基础入门刷题Python-算法篇-数据结构与算法的介绍-一种常见的贪心算法(持续更新)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言

提示:这里可以添加本文要记录的大概内容:

第一天Python数据结构与算法的详细介绍
第二天五种常见的排序算法
第三天两种常见的搜索算法
第四天两种常见的递归算法
第五天一种常见的动态规划算法
第六天一种常见的贪心算法

提示:以下是本篇文章正文内容,下面案例可供参考

一、Python数据结构与算法的详细介绍

1.Python中的常用的贪心算法

以下是Python中的一些常用算法:

2.贪心算法

贪心算法:在每一步选择中都采取最好或最优(即最有利)的选择,从而希望能够导致结果是全局最好或最优的算法。时间复杂度依具体问题而定。

3.详细的贪心代码

1)一种常见的贪心算法
python 复制代码
def activity_selection(activities):
    # 按照结束时间排序,如果结束时间相同,则按开始时间排序
    activities.sort(key=lambda x: (x[1], x[0]))
    
    # 第一个活动总是被选择
    selected_activities = [activities[0]]
    last_end_time = activities[0][1]
    
    # 遍历剩余活动
    for i in range(1, len(activities)):
        if activities[i][0] >= last_end_time:
            # 如果当前活动的开始时间不早于上一个活动的结束时间,则选择该活动
            selected_activities.append(activities[i])
            last_end_time = activities[i][1]
    
    return selected_activities
 
# 示例活动列表,格式为 (开始时间, 结束时间)
activities = [(1, 3), (2, 4), (0, 6), (5, 7), (3, 5), (5, 9), (6, 10), (8, 11), (8, 12), (2, 13), (12, 14)]
 
# 选择活动
selected = activity_selection(activities)
print("被选择的活动:", selected)

总结

提示:这里对文章进行总结:

例如:以上就是今天要讲的内容,本文简单介绍一种常见的贪心算法。

相关推荐
Eumenides_max几秒前
【股票数据API接口32】如何获取融资融券历史走势股数据之Python、Java等多种主流语言实例代码演示通过股票数据接口获取数据
java·开发语言·python·股票api接口·股票数据接口
九亿AI算法优化工作室&3 分钟前
DBO优化GRNN回归预测matlab
人工智能·python·算法·matlab·数据挖掘·回归·机器人
Tester_孙大壮8 分钟前
第30章 测试驱动开发中的设计模式解析(Python 版)
驱动开发·python·设计模式
小王子102413 分钟前
设计模式Python版 工厂方法模式
python·设计模式·工厂方法模式
Jackilina_Stone21 分钟前
【python】三帧差法实现运动目标检测
python·计算机视觉·od·运动目标检测
羑悻的小杀马特22 分钟前
计算机视觉:撕裂时空的视觉算法革命狂潮
人工智能·算法·计算机视觉
gentle_ice23 分钟前
leetcode——搜索二维矩阵II(java)
java·算法·leetcode·矩阵
Icomi_25 分钟前
【PyTorch】3.张量类型转换
c语言·c++·人工智能·pytorch·python·深度学习·神经网络
OTWOL34 分钟前
八种排序算法【C语言实现】
c语言·算法·排序算法
Doopny@42 分钟前
求阶乘(信息学奥赛一本通-2019)
算法