毕业旅行问题

小明目前在做一份毕业旅行的规划。打算从北京出发,分别去若干个城市,然后再回到北京,每个城市之间均乘坐高铁,且每个城市只去一次。由于经费有限,希望能够通过合理的路线安排尽可能的省一些路上的花销。给定一组城市和每对城市之间的火车票的价钱,找到每个城市只访问一次并返回起点的最小车费花销。

输入描述:

城市个数n(1<n≤20,包括北京)

城市间的车票价钱 n行n列的矩阵 m[n][n]

输出描述:

最小花销 s

输入例子1:

  1. 4
  2.  
  3. 0 2 6 5
  4.  
  5. 2 0 4 4
  6.  
  7. 6 4 0 2
  8.  
  9. 5 4 2 0

输出例子1:

  1. 13

例子说明1:

共 4 个城市,城市 1 和城市 1 的车费为0,城市 1 和城市 2 之间的车费为 2, 城市 1 和城市 3 之间的车费为 6,城市 1 和城市 4 之间的车费为 5。 依次类推。假设任意两个城市之间均有单程票可购买,且票价在1000元以内,无需考虑极端情况。

思路:

1、permutations模块

这里我的第一想法就是遍历所有的情况计算路费进而去最小值。

那么这里如果要遍历所有路线的话,可以用到permutations模块来获取所有的排列结果。

下面用一个列表来说明permutations模块的用法:

  1. from itertools import permutations
  2. li = [1,2,3]
  3. print(permutations(li))
  4. for i in permutations(li):
  5. print(i)

代码执行结果如下:

  1. <itertools.permutations object at 0x000001A15C7B17C8>
  2. (1, 2, 3)
  3. (1, 3, 2)
  4. (2, 1, 3)
  5. (2, 3, 1)
  6. (3, 1, 2)
  7. (3, 2, 1)

可看到permutations函数返回的是一个可迭代对象,而不是列表类型, 所以打印的时候不会打印列表。

另外要格外注意的是,permutations函数得出的所有排列情况是元组类型而非列表。

permutations()可加第二个参数,代表排列的长度:

  1. from itertools import permutations
  2. li = [1,2,3]
  3. print(permutations(li))
  4. for i in permutations(li,2):
  5. print(i)

代码执行结果如下:

  1. <itertools.permutations object at 0x0000022604F827C8>
  2. (1, 2)
  3. (1, 3)
  4. (2, 1)
  5. (2, 3)
  6. (3, 1)
  7. (3, 2)

2、代码实现

  1. import itertools
  2. n = int(input()) #城市个数n(1<n≤20,包括北京)
  3. L = [] #城市间的车票价钱 n行n列的矩阵 [n][n]
  4. for i in range(n):
  5. L.append(list(map(int, input().split(' '))))
  6.  
  7. def treaval(L, n):
  8. # 除起点之外的不同路线组合,假设起点为0号节点
  9. com = list(itertools.permutations(list(range(1, n)), n - 1)) #range函数返回的是一个可迭代对象,而不是列表类型, 所以打印的时候不会打印列表。
  10. spend = 9999 # 假设一开始花销很大
  11. for j in range(len(com)): #len(com)是可选择的路线种类数
  12. road = list(com.pop(0))# 获取其中一种路线组合road列表之后就释放,com是一个元组序列
  13. # 补全起点和终点(注意起点也是终点,形成闭环)此时road长度为n+1
  14. road.append(0)#在列表末尾添加新的对象
  15. road.insert(0, 0)#将对象插入列表
  16. x = 0 # 当前路线的花销
  17. for i in range(n):
  18. x = x + L[road[i]][road[i + 1]]
  19. if x < spend:
  20. spend = x #更新最小花销
  21. return spend
  22.  
  23. print(treaval(L, n))

今天的第二个笔试题啦!

出去跑个步,回来继续加油~

Python笔试——毕业旅行问题的更多相关文章

  1. BZOJ-1143&&BZOJ-2718 祭祀river&&毕业旅行 最长反链(Floyed传递闭包+二分图匹配)

    蛋蛋安利的双倍经验题 1143: [CTSC2008]祭祀river Time Limit: 10 Sec Memory Limit: 162 MB Submit: 1901 Solved: 951 ...

  2. BZOJ2718: [Violet 4]毕业旅行

    2718: [Violet 4]毕业旅行 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 229  Solved: 126[Submit][Status ...

  3. BZOJ 2718: [Violet 4]毕业旅行( 最长反链 )

    一不小心速度就成了#1.... 这道题显然是求最长反链, 最长反链=最小链覆盖.最小链覆盖就是先做一次floyd传递闭包, 再求最小路径覆盖. 最小路径覆盖=N - 二分图最大匹配. 所以把所有点拆成 ...

  4. 2016级算法期末模拟练习赛-A.wuli51和京导的毕业旅行

    1063 wuli51和京导的毕业旅行 思路 中等题,二分+贪心. 简化题意,将m+1个数字分成n份,ans为这n段中每段数字和的最大值,求ans最小值及其方案. 对于这种求最小的最大值,最常用的方法 ...

  5. 『Python题库 - 填空题』151道Python笔试填空题

    『Python题库 - 填空题』Python笔试填空题 part 1. Python语言概述和Python开发环境配置 part 2. Python语言基本语法元素(变量,基本数据类型, 基础运算) ...

  6. [Violet 4] 毕业旅行

    2718: [Violet 4]毕业旅行 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 672  Solved: 389[Submit][Status ...

  7. Python 笔试集(4):True + True == ?

    目录 目录 前文列表 面试题True Ture 布尔值 布尔类型是特殊的整数类型 前文列表 Python 笔试集:什么时候 i = i + 1 并不等于 i += 1? Python 笔试集(1):关 ...

  8. Python笔试、面试 【必看】

    本文由EarlGrey@编程派独家编译,转载请务必注明作者及出处. 原文:Sheena@codementor 译文:编程派 引言 想找一份Python开发工作吗?那你很可能得证明自己知道如何使用Pyt ...

  9. Python笔试面试题_牛客(待完善)

    中文,免费,零起点,完整示例,基于最新的Python 3版本.https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42 ...

随机推荐

  1. Scala 面向对象(三):package 包 (二)

    1 包对象 基本介绍:包可以包含类.对象和特质trait,但不能包含函数/方法或变量的定义.这是Java虚拟机的局限.为了弥补这一点不足,scala提供了包对象的概念来解决这个问题. package ...

  2. 概率图模型(CPD)(二)

    CPD是conditional probability distribution的缩写,翻译成中文叫做 条件概率分布.在概率图中,条件概率分布是一个非常重要的概念.因为概率图研究的是随机变量之间的练习 ...

  3. Python面向对象04 /封装、多态、鸭子类型、类的约束、super

    Python面向对象04 /封装.多态.鸭子类型.类的约束.super 目录 Python面向对象04 /封装.多态.鸭子类型.类的约束.super 1. 封装 2. 多态 3. 鸭子类型 4. 类的 ...

  4. linux专题(六):Vim编辑器

    http://dwz.date/UDf 什么是Vim编辑器 Vim是从 vi 发展出来的一个文本编辑器.代码补完.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用. 简单的来说, vi 是 ...

  5. Ethical Hacking - NETWORK PENETRATION TESTING(23)

    Detecting ARP Posionning Attacks ARP main security issues: 1. Each ARP requests/response is trusted. ...

  6. 少儿编程:python趣味编程第二课,如何在pygame中写文字

    python趣味编程第二课:本文仅针对8-16岁的青少年,所以流程是按如何去教好中小学生走的,并不适合成人找工作学习,因为进度也是按照青少年走的 大家好,我是C大叔,上一篇文章已经跟大家介绍了一款开发 ...

  7. Makefile中的奇葩字符

    % : Makefile规则通配符,一般出现在目标或是依赖中 * : shell命令中的通配符,一般出现在命令中 $@:目标的名字 $^:所有依赖的名字 $<:第一个依赖的名字 $?:所有依赖中 ...

  8. [spring cloud] -- 核心篇

    核心功能: 分布式/版本化配置 服务注册合发现 服务路由 服务和服务之间的调用 负载均衡 断路器 分布式消息传递 ...... 技术体系 组件 服务注册与发现组件:Eureka.Zookeeper和C ...

  9. [jvm] -- 类文件结构篇

    类文件结构 结构图  魔数 头四个字节,作用是确定这个文件是否为一个能被虚拟机接收的 Class 文件. Class 文件版本 第五和第六是次版本号,第七和第八是主版本号. 高版本的 Java 虚拟机 ...

  10. 软件测试必备技能,带你学习jmeter!

    一:jmeter用户变量设置: 1.在线程组鼠标右击--添加--配置元件-用户定义的变量, 2.根据业务需求自定义变量的名称,添加需要的变量和对应的值 3.在脚本对应位置添加参数 二:文件参数化: 两 ...