Python:每日一题 28(答题领鱼币)
本帖最后由 新手·ing 于 2017-4-15 09:30 编辑今日题目:很尴尬哈,这个东西应该在昨天之前发,因为这个全排列对于九宫格是很有用的。
打印出三个个位数(除0外)相加等于十五的所有可能。
**** Hidden Message *****
其实很简单的。。。我都做出来了。。。
欢迎小伙伴们,一起答题!
如果你有能力,欢迎加入我们!
已经上车老司机:@冬雪雪冬 @lumber2388779 @ooxx7788 @gopythoner
{:10_298:} 点我走上人生巅峰{:10_298:}
{:10_248:} 帅的人都上车了,而丑的人还在犹豫{:10_248:} 你今天题目都不给人看了啊 ooxx7788 发表于 2017-4-14 19:30
你今天题目都不给人看了啊
我错了{:10_243:} 题目都看不懂 小锟 发表于 2017-4-14 21:49
题目都看不懂
把三个个位数相加等于15的所有可能性打印出来 本帖最后由 dori233 于 2017-4-14 22:57 编辑
def rule_out():
mun_list = []
for mun in range(123, 999):
if '0' not in str(mun):
# 用了个暴力笨方法,用了集合
if len(set(str(mun))) == 3:
m_l = str(mun)
a1 = int(m_l) + int(m_l) + int(m_l)
if a1 == 15:
mun_list.append(mun)
return mun_list
mun1 = rule_out()
print('有%d种组合' % len(mun1))
for mun in mun1:
print('%d\n-------' % mun)
结果:
有48种组合
159
-------
168
-------
186
-------
195
-------
249
-------
258
-------
267
-------
276
-------
285
-------
294
-------
348
-------
357
-------
375
-------
384
-------
429
-------
438
-------
456
-------
465
-------
483
-------
492
-------
519
-------
528
-------
537
-------
546
-------
564
-------
573
-------
582
-------
591
-------
618
-------
627
-------
645
-------
654
-------
672
-------
681
-------
726
-------
735
-------
753
-------
762
-------
816
-------
825
-------
834
-------
843
-------
852
-------
861
-------
915
-------
924
-------
942
-------
951
-------
刚刚把两个题目标题搞混了.23333
临睡前看了一下喽
偷偷的告诉楼主,回复可以见的答案有问题,range(1,10)才行,(1,9)是不输出9的,只到8
刚刚我思路其实就是 按照27做得,没认真看 这个28,好像也没说明数字不能重复.....
mun_list = list()
for i in range(1, 10):
for z in range(1, 10):
for x in range(1, 10):
if (i+z+x == 15) and (len(set())== 3):
# 如果可以重复,(len(set())== 3)可以去掉
mun_list.append()
for z1 in mun_list:
print(z1)
{:5_90:} 只能做到这了。。不知道怎么把相同的序列删掉。。。{:5_94:}
list1 = list(range(1,10))
for i in range(0,9):
for j in range(i+1,9):
for k in range(i+2,9):
if list1 + list1 + list1 == 15:
if list1 != list1 and list1 != list1 and list1 != list1:
list2 = sorted(,list1,list1])
print('the sequence is %s'%list2)
else:
pass
else:
pass 我看不到题--
题目很简单,唯一要注意的是提高程序效率,如果x,y,z做3重循环,总共需要729次循环。优化一下,仅需要75次了。
for x in range(1, 10):
for y in range(1, 10):
z = 15 - x - y
if z > 9:
continue
elif z > 0:
print(x, y, z)
else:
break 看题。。。 做了九宫的这个不都是会的么 list1 =
res = []
for x in list1:
for y in list1:
for z in list1:
if x<y<z and len({x,y,z}) == 3 and x + y + z == 15:
res.append((x,y,z))
print(res)
结果
[(1, 5, 9), (1, 6, 8), (2, 4, 9), (2, 5, 8), (2, 6, 7), (3, 4, 8), (3, 5, 7), (4, 5, 6)] 什么题目呀
冬雪雪冬 发表于 2017-4-15 20:41
题目很简单,唯一要注意的是提高程序效率,如果x,y,z做3重循环,总共需要729次循环。优化一下,仅需要75次 ...
请问一下如何剔除同样的序列啊,比如771和177 sdzxzh 发表于 2017-5-5 23:22
请问一下如何剔除同样的序列啊,比如771和177
这样不会有重复序列 比如771与177
for x in range(1,10):
for y in range(1,10):
for z in range(1,10):
if x + y + z == 15 and x<=y<=z:
print(x,y,z)
sdzxzh 发表于 2017-5-5 23:22
请问一下如何剔除同样的序列啊,比如771和177
排序一下,如果相同就忽略掉。 from itertools import permutations as pt
combol = pt(range(1,10),3)
for i in combol:
a, b, c = i
if a+b+c==15:
print(a,b,c) s = set()
for i in range(1,10):
for j in range(1,10):
for k in range(1,10):
if i+j+k == 15 and len({i,j,k})==3:
# 利用集合的无序唯一去掉重复
s.add(frozenset((i,j,k)))
for a in s: print(*a)