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

Python 学习 第三册 第12章 图的最优化问题

----用教授的方式学习。

目录

12.1图的最优化问题

12.1.1最短路径:深度优先搜索和广度优先搜索


12.1图的最优化问题

我们下面研究另一种最优化问题。假设你有一个航空公司航线的价格列表,其中包括美国任意两个城市之间的航班价格。假设有3个城市A、B和C,从A出发经过B到达C的价格是从A到B的价格加上从B到C的价格。你可能会有以下几个问题:

·某两个城市之间最少的停留次数是多少?

· 某两个城市之间最便宜的飞机票价是多少?

· 某两个城市之间,如果停留次数不超过两次,那么最便宜的飞机票价是多少?

· 如果想访问多个城市,那么最便宜的路线是什么?

所有这些问题(以及许多其他问题)都可以轻松转化为图的问题。

图是由边连接起来的节点对象的集合,边也可称为弧,节点也可称为顶点。如果边是单向的,则图称为有向图。在有向图中,从节点n1到n2有一条边,我们就称n1为源节点或父节点,n2为目标节点或子节点。

以下定义了几个类,分别实现了对应于节点、加权边和普通边的抽象类型。

class Node(object): def __init__(self, name): """假设name是字符串""" self.name = name def getName(self): return self.name def __str__(self): return self.name 
class Edge(object): def __init__(self, src, dest): """假设src和dest是节点""" self.src = src self.dest = dest def getSource(self): return self.src def getDestination(self): return self.dest def __str__(self): return self.src.getName() + '->' + self.dest.getName() 
class WeightedEdge(Edge): def __init__(self, src,
http://www.lryc.cn/news/377274.html

相关文章:

  • 建筑工程乙级资质与工程质量控制体系的构建
  • kafka学习笔记07
  • MQTTfx连接阿里云(详细版)
  • Vue3使用provide和inject实现孙组件给爷组件传递数据
  • 昇思25天学习打卡营第1天|基本介绍及快速入门
  • C#.Net筑基-类型系统②常见类型
  • 【人机交互 复习】第5章 交互式系统的需求
  • 知识的补充
  • 微信小程序请求服务器报ERR_CONNECTION_RESET
  • SpringMVC:拦截Mybatis的mapper
  • MySQL查询性能优化解决方案
  • 系统安全(补充)
  • 腾讯云[HiFlow】| 自动化 -------HiFlow:还在复制粘贴?
  • 音视频入门基础:H.264专题(3)——EBSP, RBSP和SODB
  • 误删群晖NAS数据有什么找回的方法?
  • 【CRASH】freelist异常导致的异常地址访问
  • 【QT】C++ || 左值引用、右值引用、移动语义、完美转发
  • 【深度学习驱动流体力学】计算流体力学算例剖析与实现
  • Midjourney角色一致性如何控制两个人物
  • Python基础-引用参数、斐波那契数列、无极分类
  • 【MySQL统计函数count详解】
  • 大数据的发展,带动电子商务产业链,促进了社会的进步【电商数据采集API接口推动电商项目的源动力】
  • Python类中变量定义详解
  • c++ extern 关键字详解
  • 计算机网络:运输层 - TCP 流量控制 拥塞控制
  • Python学习打卡:day10
  • 新书速览|Ubuntu Linux运维从零开始学
  • [Qt的学习日常]--窗口
  • Vue发送http请求
  • 学习使用js和jquery修改css路径,实现html页面主题切换功能