当前位置: 首页 > article >正文

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

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

文章目录

  • 前言
  • 一、Python数据结构与算法的详细介绍
    • 1.Python中的常用的贪心算法
      • 2.贪心算法
      • 3.详细的贪心代码
        • 1)一种常见的贪心算法
  • 总结


前言

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

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

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

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

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

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

2.贪心算法

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

3.详细的贪心代码

1)一种常见的贪心算法
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)

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文简单介绍一种常见的贪心算法。


http://www.kler.cn/a/518599.html

相关文章:

  • 大数据之路:阿里巴巴大数据实践(1)
  • 二叉搜索树中的众数(力扣501)
  • Synology 群辉NAS安装(4)docker-compose
  • 在Windows系统中本地部署属于自己的大语言模型(Ollama + open-webui + deepseek-r1)
  • 《探秘:人工智能如何为鸿蒙Next元宇宙网络传输与延迟问题破局》
  • 数据结构:二叉树—面试题(二)
  • flutter跨端UI框架简介
  • 简识JVM中的STW
  • 【二叉树】4. 判断一颗二叉树是否是平衡二叉树。5. 对称二叉树。6. 二叉树的构建及遍历 7. 二叉树的分层遍历 。
  • 使用 .NET Core 6.0 Web API 上传单个和多个文件
  • 12、MySQL锁相关知识
  • 分布式系统架构怎么搭建?
  • Flutter_学习记录_导航和其他
  • 小程序电商运营内容真实性增强策略及开源链动2+1模式AI智能名片S2B2C商城系统源码的应用探索
  • Linux之NetLink学习笔记
  • docker Ubuntu实战
  • 计算机图形学:实验四 带纹理的OBJ文件读取和显示
  • vue3自定义表格生成动态列
  • linux系统中的 scp的使用方法
  • 【面试题】 Java 三年工作经验(2025)
  • 2025美赛数学建模C题 奥运奖牌模型保姆级教程讲解|模型讲解
  • 为AI聊天工具添加一个知识系统 之68 详细设计 之9 三种中台和时间度量 之1
  • SpringBoot打包为JAR包或WAR 包,这两种打包方式在运行时端口将如何采用?又有什么不同?这篇文章将给你解惑
  • ESP8266 NodeMCU与WS2812灯带:实现多种花样变换
  • 家政预约小程序09服务管理
  • 使用Redis缓解数据库压力+三种常见问题