博客
关于我
python笔记1-用python解决小学生数学题
阅读量:464 次
发布时间:2019-03-06

本文共 900 字,大约阅读时间需要 3 分钟。

前几天有人在群里给小编出了个数学题:

假设你有无限数量的邮票,面值分别为6角,7角,8角,请问你最大的不可支付邮资是多少元?

 

小编掰着手指头和脚趾头算了下,答案是:1.7元

那么问题来了?为啥是1.7呢,于是小编用python解决了这个小学数学题。

 

一、排列组合

假设6、7、8角各有50张(50张够了),先计算出所有的可能组合

 

 

二、排序、去重

  1. 先对组合就行排序,从小到大的顺序,排队站好,这里用到sort()函数(要是你用冒泡排序,那你就out啦!)

  2. sort函数只是对list序列排序,并没有返回值

  3. 排序完成后,接下来就是去掉重复的数据

 

 

三、取出不能生成的数字

  1. 不在上面组合里面的数字就是不能生成的数字了,于是我们可以先取出来。

  2. 取出来后的数据放到r队列里。

  3. 从r队列取最后一个数据,就是答案啦。

 

 

四、参考代码

# coding:utf-8

a = 6
b = 7
c = 8
t = 50     # 票的张数
s = []     # 排列组合全部放到这里
# 生成的组合
for i in range(t+1):
    s1 = a*i
    s.append(s1)
    for j in range(t+1):
        s2 = a*i+b*j
        s.append(s2)
        for k in range(t+1):
            s3 = a*i + b*j + c*k
            s.append(s3)
# 排序
s.sort()
# 去掉重复
news = []
for i in s:
    if i not in news:
        news.append(i)
print("组合生成的最大数%s"%news[-1])
# 提取不在列表列表中的数字
r = []
for i in range(6*t):
    if i in news:
        pass
    else:
        r.append(i)
print("组合不能生成的数字%s"%r)
print("不能生成的最大数字为%s"%r[-1])​

 

如果当年小学时候就能学会python,妈妈就不用担心我的学习了!

在学习过程中有遇到疑问的,可以加selenium(python+java) QQ群交流:232607095

转载地址:http://jkmbz.baihongyu.com/

你可能感兴趣的文章
centos7中配置elasticsearch集群和离线安装x-pack
查看>>
elasticsearch之模块【节点】
查看>>
C语言字节数----小知识
查看>>
一名初学者关于SSH整合的问题
查看>>
【Linux】04 实验笔记
查看>>
Java 并发之虚假唤醒
查看>>
Linux命令之------free
查看>>
C语言线程池的实现
查看>>
不同进程共享链表方法:用共享内存创建链表
查看>>
(六)多进程实现TCP服务端
查看>>
(Mysql 二)Linux C语言显示mysql数据库中某个表的数据
查看>>
C++拷贝构造函数与浅拷贝,深拷贝
查看>>
JAVA单例模式
查看>>
qt 的模块
查看>>
AWT 窗口事件
查看>>
数组指针和指针数组
查看>>
css 画三角形箭头
查看>>
安装卸载mysql_win10
查看>>
火狐浏览器无法载入配置文件
查看>>
idea中maven工程pom.xml配置文件自动导入依赖
查看>>