人山人海(python实现)

2023-12-13 10:30
文章标签 python 实现 人山人海

本文主要是介绍人山人海(python实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

人山人海(通信网理论基础)

小朱和小白同学来到大学旁的商圈凤巢玩耍。商圈中有n个娱乐场馆和m条路连接这些场馆。由于国庆期间出门玩耍的人数增加,每条路上都积攒了不同数量的游客。小朱同学不想经过游客太多的路径,所以求助成都某大学精通图算法的小白同学。问,任意两个场馆之间最大游客数量最小的那条路的最大游客数量。
如图:
在这里插入图片描述

a-g两点间的路径,只有a-c-f-d-g这条路的最大游客数量是最小的,为80。
b-d两点间的路径,只有b-a-c-f-d这条路的最大游客数量是最小的,为80。

输入:第一行m<10000为图的边数,第二行为图的点数。之后m<100行,每行有三个正整数I,j,k表示节点I,j相连,游客人数k<10000。之后一行一个正整数t<n(n-1)表示询问次数。之后t行,每一行两个正整数a,b(a,b<n),表示询问a,b之间最大游客数量最小的那条路的最大游客数量。
输出:
对于每次询问输出一行,该行为一个正整数,表示最大游客数量。

样例:
输入:
5
4
1 2 10
1 3 20
2 3 15
2 4 5
3 4 30
1
04
输出:
10

题目分析:

这个题目的思路和温差问题有些相似,先将图中所有的边按权重从小到大排列,从排列好的边集合A依次取出边加入一个新的集合B,每加入一条边都要判断给定的起点终点在集合B中的边与边对应的点构成的图里是否可达,如果可达就停止加边,将集合B中最大的边权值输出。

import sys, time, mathedgeLinks = dict()
edgeLinks_dfs = dict()
stack = []
edgeWeightsAbout = dict()
edgeWeightsAbout1 = dict()
edgeWeight = dict()
Cu = []
J = []
S = []
Path = []
start = []
end = []
stack = []
T = []
Q = []
ju = 0
start_1 = time.time()def DFS(start, end):global stack, T, edgeLinks_dfs, p, justack.append(start)if start == end:p = 1ju = 1# print("找到路径:%s" %(stack))stack.clear()else:if len(edgeLinks_dfs) != 0:if start in edgeLinks_dfs:for nextPoint in edgeLinks_dfs[start]:  # start不为全局变量 在递归后就变为了nextPointif nextPoint not in stack:DFS(nextPoint, end)if p == 1:stack.clear()returnelse:p = -1stack.pop()global p
p = 0
f = open('data5.txt', 'r')
P = int(f.readline())
V = int(f.readline())
if V > 1 and V <= 10000 and P <= 10000:for item2 in range(P):a, b, c = map(int, f.readline().split())wi = int(c)if str(a) not in edgeLinks: edgeLinks[str(a)] = set()if str(b) not in edgeLinks: edgeLinks[str(b)] = set()edgeLinks[str(a)].add(str(b))edgeLinks[str(b)].add(str(a))# 进行权重分类 权重一样的放到一个集合里面if wi not in edgeWeightsAbout.keys():edgeWeightsAbout[wi] = []if {str(a), str(b)} not in edgeWeightsAbout[wi]:edgeWeightsAbout[wi].append({str(a), str(b)})if str(a) not in edgeWeight:edgeWeight[str(a)] = dict()if str(b) not in edgeWeight:edgeWeight[str(b)] = dict()edgeWeight[str(a)].update({str(b): c})edgeWeight[str(b)].update({str(a): c})NP = int(f.readline())for item3 in range(NP):m, n = map(int, f.readline().split())start.append(str(m))end.append(str(n))S = sorted(edgeWeightsAbout.keys(), reverse=False)for item6 in range(len(S)):edgeWeightsAbout1.update({S[item6]: edgeWeightsAbout[S[item6]]})for item12 in range(NP):T.clear()Cu.clear()J.clear()edgeLinks_dfs.clear()stack.clear()ju = 0for item7 in range(len(S)):if(ju==1):breakfor item8 in range(len(edgeWeightsAbout1[S[item7]])):if(ju==1):breakfor item11 in edgeWeightsAbout1[S[item7]][item8]:J.append(item11)if J[0] not in edgeLinks_dfs: edgeLinks_dfs[J[0]] = set()if J[1] not in edgeLinks_dfs: edgeLinks_dfs[J[1]] = set()edgeLinks_dfs[J[0]].add(J[1])edgeLinks_dfs[J[1]].add(J[0])Cu.append(str(J[0]))Cu.append(str(J[1]))J.clear()if (len(edgeLinks_dfs) == 0):breakelse:if (len(edgeLinks_dfs) == 0):breakelse:if start[item12] in Cu and end[item12] in Cu:DFS(start[item12], end[item12])if (p == 1):T.append(edgeWeight[Cu[len(Cu) - 2]][Cu[len(Cu) - 1]])if (ju == 1):print('%s->%s'%(start[item12],end[item12]),end='  ')print(T)else:print('no path')
end_1 = time.time()
print('Running time: %s Seconds' % (end_1 - start_1))

该代码采取读取文件形式,只需将文件路径放入即可。
输出:为起点->终点 最大游客数量
输出为“no path”意味着没有该路径

正常输出如下:
1->10 [10]
1->13 [10]
2->25 [13]
45->70 [11]
8->89 [8]
Running time: 0.009997129440307617 Seconds

这篇关于人山人海(python实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/488117

相关文章

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

python 字典d[k]中key不存在的解决方案

《python字典d[k]中key不存在的解决方案》本文主要介绍了在Python中处理字典键不存在时获取默认值的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录defaultdict:处理找不到的键的一个选择特殊方法__missing__有时候为了方便起见,

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画

Python pyinstaller实现图形化打包工具

《Pythonpyinstaller实现图形化打包工具》:本文主要介绍一个使用PythonPYQT5制作的关于pyinstaller打包工具,代替传统的cmd黑窗口模式打包页面,实现更快捷方便的... 目录1.简介2.运行效果3.相关源码1.简介一个使用python PYQT5制作的关于pyinstall

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur