新手·ing 发表于 2017-4-14 18:47:08

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:52

你今天题目都不给人看了啊

新手·ing 发表于 2017-4-14 19:45:34

ooxx7788 发表于 2017-4-14 19:30
你今天题目都不给人看了啊

我错了{:10_243:}

小锟 发表于 2017-4-14 21:49:11

题目都看不懂

新手·ing 发表于 2017-4-14 21:50:18

小锟 发表于 2017-4-14 21:49
题目都看不懂

把三个个位数相加等于15的所有可能性打印出来

dori233 发表于 2017-4-14 22:44:32

本帖最后由 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

dori233 发表于 2017-4-14 23:36:48

临睡前看了一下喽
偷偷的告诉楼主,回复可以见的答案有问题,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)

观测者 发表于 2017-4-15 12:25:34

{:5_90:}

rosen 发表于 2017-4-15 16:26:37

只能做到这了。。不知道怎么把相同的序列删掉。。。{: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

保登心爱 发表于 2017-4-15 20:04:39

我看不到题--

冬雪雪冬 发表于 2017-4-15 20:41:05

题目很简单,唯一要注意的是提高程序效率,如果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

老甲鱼与小甲鱼 发表于 2017-4-16 17:46:05

看题。。。

余欲渔 发表于 2017-4-17 11:40:04

做了九宫的这个不都是会的么

技术部-李宁 发表于 2017-5-3 13:15:18

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-5-3 16:00:30

什么题目呀

sdzxzh 发表于 2017-5-5 23:22:16

冬雪雪冬 发表于 2017-4-15 20:41
题目很简单,唯一要注意的是提高程序效率,如果x,y,z做3重循环,总共需要729次循环。优化一下,仅需要75次 ...

请问一下如何剔除同样的序列啊,比如771和177

sdzxzh 发表于 2017-5-5 23:33:19

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)

冬雪雪冬 发表于 2017-5-6 08:40:15

sdzxzh 发表于 2017-5-5 23:22
请问一下如何剔除同样的序列啊,比如771和177

排序一下,如果相同就忽略掉。

willLin 发表于 2017-5-11 16:53:38

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)

solomonxian 发表于 2017-6-12 18:07:42

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)
页: [1] 2 3 4
查看完整版本: Python:每日一题 28(答题领鱼币)