题目:有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?

**程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。

个人解题思路

利用排列组合知识算出总共有4X3X2= 24个数,构造每个数加入列表中,打印输出。

  import random
li = ["1","2","3","4"]
all_sum_num = 4*4*4
new_sum_list = []
for i in range(all_sum_num):
choose_li = random.sample(li,3)
new_num_str = "".join(choose_li)
new_sum_list.append(new_num_str)
num_set = set(new_sum_list)
num_str_list = list(num_set)
print(num_str_list)
print(len(num_str_list))

  

分析:这种写法有个漏洞,就是随机取出的3个数并不能完全取完所有可能的数,造成结果不唯一,每次运行程序可能结果都不一致。

参考解答方法:

  li = []
for i in range(1,5):
for j in range(1,5):
for k in range(1,5):
if i != k and i != j and j != k:
num = i*100 + j*10 + k
li.append(num)

print(li)
print(len(li))

  

分析:用3个for循环,加上if条件判断,将产生的数加入列表即可

上述代码可以继续精简

  li1 = [1,2,3,4]
li2 = [a*100 + b*10 +c for a in li1 for b in li1 for c in li1 if a != b and a != c and b != c]
print(li2)
print(len(li2))

  

分析:采用列表解析式,分别对百位、十位、个位的数字进行生成并合成列表的元素。

相关知识:

列表解析式

列表解析式,也可以叫列表推导式

语法

  [expression for iter_var in iterable1] 



[expression for iter_var2 in iterable2 ...

                  for iter_varN in iterableN]


[expression for iter_var in iterable1

                  if condition]

列表解析式是将一个可迭代对象(如列表)转换成另一个列表的工具。在转换过程中,可以指定元素必须符合某一条件,并按照指定的表达式进行转换,才能添加至新的列表中。

例子1

  
  #生成1*1,2*2,3*3,4*4,5*5,6*6,9*9的序列
li1 = [x*x for x in range(1,11)]
print(li1)

  

例子2

使用两层循环的情况

  li1 = [m+n for m in range(3) for n in range(2)]
print(li1)

#li1的列表解析式等价于下面的嵌套for循环,即m是来自于第一个for循环,n的数值是来自于第二个for循环
li2 = []
for i in range(3):
for j in range(2):
num = i+j
li2.append(num)
print(li2)

  

例子3

  #获取列表中嵌套列表的元素,生成一个无嵌套的新列表
li3=[[1,2],[3,4,5],[6,7],[8]]
print([x for i in li3 for x in i])

  

例子4

  
  # 获取两个列表对应位的乘积
lia=[2,3,4,5]
lib=[3,4,5,6]
zip_li = zip(lia,lib)
print(zip_li) #这里产生的zip对象是两个一一对应的元组,可以用for循环取出来
print([i*j for i,j in zip(lia,lib)])

  

例子5

  # 获取文本中所有单词的第1个字符
text = "Alibaba founder Jack Ma laughs off AC Milan football club purchase rumors"
first_charts=[word[0] for word in text.split()]
print(first_charts)

  

例子6

列表生成式加三元运算

  # 将列表中所有能转化为数字的字符串转化为数字
lix = ['1','2','3','i','8']
liy = [int(x)if x.isdigit()else x for x in lix]
print(liy)

例子7

  # 将列表中小于5的数*10
lic = [1,3,4,10,18]
print([x*10 for x in lic if x < 5 ])
#注意这里是列表解析式,只是加上了条件判断,注意与列表解析式加三元运算的区别,这里加不了else
print([x*10 if x < 5 else x for x in lic])
#也可以改写成列表解析加三元运算

  

(本文编号001,首发于2018年9月11日,修改于2018年9月12日)

Python:每日一题001的更多相关文章

  1. Python每日一题 001

    Github地址:https://github.com/Yixiaohan/show-me-the-code Talk is Cheap, show me the code. --Linus Torv ...

  2. Python每日一题 004

    将 0001 题生成的 200 个激活码(或者优惠券)保存到 Redis 非关系型数据库中. 代码 import redis import uuid # 创建实例 r=redis.Redis(&quo ...

  3. Python每日一题 003

    将 002 题生成的 200 个激活码(或者优惠券)保存到 MySQL 关系型数据库中. 代码 import pymysql import uuid def get_id(): for i in ra ...

  4. Python每日一题 002

    做为 Apple Store App 独立开发者,你要搞限时促销,为你的应用生成激活码(或者优惠券),使用 Python 如何生成 200 个激活码(或者优惠券)? 在此生成由数字,字母组成的20位字 ...

  5. Python每日一题 009

    题目 有个目录,里面是你自己写过的程序,统计一下你写过多少行代码.包括空行和注释,但是要分别列出来. 代码 参照网络上代码 # coding: utf-8 import os import re # ...

  6. Python每日一题 008

    题目 基于多线程的网络爬虫项目,爬取该站点http://www.tvtv.hk 的电视剧收视率排行榜 分析 robots.txt User-agent: Yisouspider Disallow: / ...

  7. Python每日一题 007

    题目 你有一个目录,放了你一个月的日记,都是 txt,为了避免分词的问题,假设内容都是英文,请统计出你认为每篇日记最重要的词. 很难客观的说每篇日记中最重要的词是什么,所以在这里就仅仅是将每篇日记中出 ...

  8. Python每日一题 006

    题目 你有一个目录,装了很多照片,把它们的尺寸变成都不大于 iPhone5 分辨率的大小. 如果只是单纯的通过将图片缩放到iPhone5分辨率大小,显然最后呈现出来的效果会很糟糕.所以等比例缩放到长( ...

  9. Python每日一题 005

    任一个英文的纯文本文件,统计其中的单词出现的个数. 代码 # coding:utf-8 import re def get_word(filename): fp=open(filename," ...

随机推荐

  1. jmeter分布式、linux运行

    一.jmeter分布式压测(多台电脑一起压测) 1.有多台电脑,每台电脑上都有jmeter,而且这几台电脑都互相能ping通 2.在我的电脑的jmeter,bin目录下,修改jmeter.proper ...

  2. flutter学习地址

      Flutter - 不一样的跨平台解决方案: 关于Flutter,你想知道的都在这里了!: Flutter 时间表 2015 年 4 月,Flutter(最初代号 Sky)在 Dart Devel ...

  3. LeetCode【88. 合并两个有序数组】

    首先想到的方法就是,假设一个nums3数组,然后,比较nums1与nums2的数值大小,然后,放在nums3中,再将nums3转移到nums1中. 实现起来很麻烦,1.没有考虑到下标问题,结果就Arr ...

  4. XAMPP 虚拟主机配置,实现多域名访问本地项目

    XAMPP 虚拟主机配置,实现多域名访问本地项目 1.首先你既然要配置多个虚拟主机,那你肯定需要多个站点的目录文件.你可以在e盘创建 www文件夹,然后在该文件件中新建两个站点目录,假设test.co ...

  5. Tomcat的目录结构详细介绍(超全)

    打开tomcat的解压之后的目录可以看到如下的目录结构:  1.bin: bin目录主要是用来存放tomcat的命令,主要有两大类,一类是以.sh结尾的(linux命令),另一类是以.bat结尾的(w ...

  6. ApacheTraffic Server 使用ssd 以及裸盘

    使用裸设备后可以使用ATS自身的文件子系统,可以获得更好的IO性能,也是官方推荐的方式.下面为例 删除分区,不使用操作系统自带分区 `fdisk -l /dev/sde` 修改相关设备权限并创新相关设 ...

  7. IDEA run下output标签悬浮/弹出状态

    就是这样,在哪儿有一个恢复布局标签

  8. [leetcode]2. Add Two Numbers.cpp

    You are given two non-empty linked lists representing two non-negative integers. The digits are stor ...

  9. 一个类似于jq的小型库

    本人写了一个类似于jq的小型库,不过只是写了部分方法而已.并没有jq那么全面,下面就介绍下有哪些方法可以使用 第一个是选择器, 选择器比较简单 只支持ID选择器 $(‘#id_name’) Class ...

  10. 学习node.js 第2篇 介绍node.js 安装

    Node.js - 环境安装配置 如果愿意安装设置Node.js环境,需要计算机上提供以下两个软件: 一.文本编辑器 二.Node.js二进制安装包 文本编辑器 这将用来编写程序代码. 一些编辑器包括 ...