笔试-基站维护

应用

小王是一名基站维护工程师,负责某区域的基站维护。某地方有n个基站(1<n<10),已知各基站之间的距离s(0<s<500),并且基站到基站y的距离,与基站y到基站的距离并不一定会相同。

小王从基站1出发,途经每个基站1次,然后返回基站1,需要请你为他选择一条距离最短的路。

实现

python 复制代码
n = int(input("站点数:"))

distance = []
for i in range(0, n):
    str = input(f"站点{i}到各站点的距离:").split()
    lst = [int(s) for s in str]
    distance.append(lst)
# print(distance)

visited = [0]
current = 0
sum = 0

result= [5000]

def route(visited, current, sum):
    
    if len(visited) == 1:
        for i in range(1, n):
            temp = sum + distance[0][i]
            visited.append(i)
            route(visited, i, temp)
            
            # 复原
            visited.pop()

    if len(visited) > 1 and len(visited) < n:
        for i in range(1, n): 
            if distance[current][i] != 0 and i not in visited:
                temp = sum + distance[current][i]
                visited.append(i)
                route(visited, i, temp)

                visited.pop()
    
    if len(visited) == n:
        temp = sum + distance[current][0]
        # visited.append(0)
        if temp < result[0]:
            result[0] = temp
# 启动
route(visited, current, sum)
print(result[0])
powershell 复制代码
站点数:3
站点0到各站点的距离:0 2 1
站点1到各站点的距离:1 0 2
站点2到各站点的距离:2 1 0
3

站点数:4
站点0到各站点的距离:0 2 1 3
站点1到各站点的距离:1 0 2 5
站点2到各站点的距离:2 1 0 4
站点3到各站点的距离:3 2 6 0
8
相关推荐
bestcxx8 分钟前
多个维度对 Java、Python、C#、Go 这四种主流编程语言进行比较
java·python·c#
装杯让你飞起来啊8 分钟前
Kotlin 条件判断 if / when 与智能转换 smart cast
开发语言·python·kotlin
计算机毕业编程指导师36 分钟前
【大数据毕设推荐】Hadoop+Spark电影票房分析系统,Python+Django全栈实现 毕业设计 选题推荐 毕设选题 数据分析 机器学习 数据挖掘
大数据·hadoop·python·计算机·spark·毕业设计·电影票房
唐叔在学习1 小时前
TodoList:我的待办助手
python·程序员·ai编程·待办应用
郝学胜-神的一滴1 小时前
深度学习损失函数:从原理到实战之 Smooth L1 Loss
人工智能·pytorch·python·深度学习·机器学习·数据挖掘
hhzz1 小时前
第1天:初识Python
开发语言·python·学习编程
黄粱梦醒2 小时前
UV快速搭建新项目
python
小学生-山海2 小时前
【YOLO系列】基于YOLOv8/v11/v26与tkinter的车流量统计系统设计
python·yolo
szial2 小时前
Python Click 教程:从函数到专业命令行工具
开发语言·python
u0119608232 小时前
ray 依赖分发
python