- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
所以我有一张公共(public)汽车可以乘坐的路线列表以及每条路线的距离:
routes = {'AB':5, 'BC':4, 'CD':8, 'DC':8, 'DE':6, 'AD':5, 'CE':2, 'EB':3, 'AE':7}
或者现在只是一个列表,因为距离现在还不重要:
paths = ['AB', 'BC', 'CD', 'DC', 'DE', 'AD', 'CE', 'EB', 'AE']
现在我正在尝试获取公共(public)汽车在给定起点和终点的情况下可能采用的路线列表,然后我想尝试合并最大停靠点数以限制数据输出。目前我有这个功能:
def route_variations(first_stop, last_stop, max_stops):
possiblepaths = []
for path in paths:
x = path[0] #first letter of each route
if first_stop == x:
possiblepaths.append(path)
for path in paths:
y = path[-1] #last letter of each route
if last_stop == y:
possiblepaths.append(path)
return possiblepaths
例如,如果我想从 C 开始和结束
route_variations('C','C', 10)
将返回以 C 开头并以 C 结尾的路线列表,即。 -> ['CD', 'CE', 'BC', 'DC']
所以现在我也需要连接路由。路线 C-E-B-C 需要我的输出中缺少的 E-B 路线。知道如何开始实现吗?然后加入他们实现像CDC这样的全路由而不是CD和DC?
最佳答案
正如对您问题的评论所暗示的那样,图论中有众所周知的算法来寻找路径。
但是,只是为了学习(说真的,只是为了学习,这段代码并不真正适合这个任务的一般情况),我会尝试提供一个结构有点像你的简单例子代码,这样你就可以看到你在获取那些“连接路由”时遗漏了什么
基本原则是,当你找到一条正确的路径(通过比较第一个字母)时,你会寻找所有以这条路径开头的路径,通过再次调用函数,从自身内部(即递归),第二个字母路径。:
paths = ['AB', 'BC', 'CD', 'DC', 'DE', 'AD', 'CE', 'EB', 'AE']
def route_variations(first_stop, last_stop, max_stops):
possible_routes = []
if max_stops == 0 or first_stop == last_stop:
return possible_routes
for path in paths:
x,y = path
if first_stop == x:
if last_stop == y:
possible_routes.append([path])
routes_from_this_stop = route_variations(y, last_stop, max_stops - 1)
possible_routes.extend([[path] + route for route in routes_from_this_stop])
return possible_routes
print(route_variations('A', 'C', 10))
输出是:
[['AB', 'BC'], ['AD', 'DC'], ['AD', 'DE', 'EB', 'BC'], ['AE', 'EB', 'BC']]
注意:如果 route 有圆圈,您会看到许多类似的路线绕着圆圈(长度受 max_stops
限制)。
注意 2: 当 start 和 stop 相同时,这将不起作用,您将得到一个空结果,因此您的具体示例在这里不起作用 :(
关于python - 巴士路线 : obtaining multiple routes from only 2 stops per route,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57039220/
我正在尝试设计我的输入:文件。以下 SO 问题让我完成了 95% 的任务。区别在于我使用的是 HTML5 multiple=multiple 属性。 How to style "input file"
我一直在进行一项实验,其中多个调查参与者使用可穿戴技术聆听多首音乐来跟踪多条信息,两个例子是 BPM(心率)和 T(体温)。 目标是衡量每首音乐(以用户反馈为特征)对人类情感的影响。 目前,所有数据都
我使用 jquery 添加/删除输入 我使用append为日期/收入添加多个Tr 我还使用另一个附加来添加多个 td 以获取同一日期 Tr 中的收入 我添加多个日期输入,并在此表中添加多个收入输入 我
在 Android 中,有一种方法可以为项目中的所有模块生成签名的 APK。例如。我有以下项目 Project -- Library Module -- Module 1 -- Modul
我有一个用于网站展示的系统。 展览数据可能来自差异表中的多个数据。 喜欢这个设计: Table [ExhibitionType] used for differentiate category. Ta
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
我正在使用 UILocalnotification...收到通知时,当应用程序处于事件模式时我打开 viewcontroller...但是如果同时收到多个通知...我如何打开多个 viewcontro
我遇到的问题是一个策略浏览器游戏,它有 7 种类型的值。问题如下: 我在 $_POST 中获得了 7 个不同的值,包括从索引 unit_1 到索引 unit_7。这 7 个值是 0 到 20 之间的整
这个问题已经有答案了: Search Large Text File for Thousands of strings (3 个回答) 已关闭10 年前。 我想在多个文件上“grep”多个正则表达式。
我经常对如何在我的应用程序中解决这个问题感到矛盾。我使用了很多选项,包括: 一个通用的多选 - 这是我最不喜欢和最很少使用的选项。我发现可用性非常糟糕,一个简单的误点击就会毁了你所有的辛勤工作。 “自
以下是 couchbase 中的示例文档之一。 { "name":"abc", "friends":["a","b","c"], "bestfriends":["x","y","z"] }
我有 4 张 table 。 表组 | ID | NAME | 1 Premium 2 Silver 表用户 | ID | group_id | NAME | 1
我正在开发一个使用第三方服务(Facebook、Google 等)对用户进行身份验证的应用程序。我为每个用户提供一个内部 ID(uuid v4),该 ID 与他们的第 3 方 ID 相关联。现在,我的
我是 bicep 新手,一直在努力实现 Bicep 脚本来部署具有许多主题和订阅的 Azure 服务总线。 我添加的每个主题都有可变数量的订阅(例如,通知主题可能有 3 个订阅,但分析主题可能有 2
我是 bicep 新手,一直在努力实现 Bicep 脚本来部署具有许多主题和订阅的 Azure 服务总线。 我添加的每个主题都有可变数量的订阅(例如,通知主题可能有 3 个订阅,但分析主题可能有 2
我必须创建一个大型数据库。它将保存来自 100 多个设备的数据,并不断更新数据库。每 10 秒,每个设备都会更新数据库中的一行。是为每个设备数据建立一个单独的表还是将数据与设备 ID 放在同一个表中更
我需要在 Activity 开始时显示“正在加载”进度对话框,然后在加载完成后显示一些内容。在我的 onresume 中,我有类似这样的代码: loadThread = true; Thread sh
我有一个 html 表单 当我提交表单时,假设对于 id = 1,数量为 5 或 对于 id = 3,数量为 8。如何在java脚本或jquery中获取这些值并将这些信息提交到服务器?我
我正在创建一个 Mozilla 扩展程序,通过单击“转换按钮”(标签:转换)将网页内容转换为其他语言它的标签被转换为英文,以便单击该按钮(标签:英文)内容被转换为原始形式 我尝试为每个选项卡设置属性“
我正在尝试根据 进行搜索 我通过运行代码从 select 中获取值: for($i=0;$i= '$age_from' AND users.user_age = '$age_from' AND u
我是一名优秀的程序员,十分优秀!