zoukankan      html  css  js  c++  java
  • 24点

    1、穷举迭代

     1 #coding:utf8
     2 from __future__ import division
     3 import itertools
     4 
     5 def dian(a,b,c,d):
     6     num_list = [str(a),str(b),str(c),str(d)]
     7     all = []
     8     #遍历所有数字组合的可能性
     9     for n in itertools.permutations(num_list,4):
    10         all.append(n)
    11 
    12     #遍历所有符号组合的可能性
    13     ops = ['+','-','*','/']
    14     ops_list = [[x,y,z] for x in ops for y in ops for z in ops]
    15 
    16     #数字和符号组合
    17     z = []
    18     for i in all:
    19         for j in ops_list:
    20             j.append('')
    21             z.append(zip(i,j))
    22 
    23     #组成表达式
    24     biao1 = []
    25     for i in z:
    26         s=''
    27         for j in i:
    28             s+=j[0]+j[1]
    29         biao1.append(s)
    30 
    31     #加上第一个(
    32     biao2=[]
    33     for i in biao1:
    34         for j in range(6):
    35             g = list(i)
    36             g.insert(j,'(')
    37             s=''
    38             for k in g:
    39                 s+=k
    40             biao2.append(s)
    41 
    42     # 加上第一个)
    43     biao3=[]
    44     for i in biao2:
    45         for j in range(1,7):
    46             g = list(i)
    47             g.insert(j,')')
    48             s=''
    49             for k in g:
    50                 s+=k
    51             biao3.append(s)
    52     # 加上第二个(
    53     biao4=[]
    54     for i in biao3:
    55         for j in range(6):
    56             g = list(i)
    57             g.insert(j,'(')
    58             s=''
    59             for k in g:
    60                 s+=k
    61             biao4.append(s)
    62     # 加上第二个)
    63     biao5=[]
    64     for i in biao4:
    65         for j in range(1,7):
    66             g = list(i)
    67             g.insert(j,')')
    68             s=''
    69             for k in g:
    70                 s+=k
    71             biao5.append(s)
    72     print(len(biao5))
    73     for i in biao5:
    74         try:
    75             result = eval(i)
    76             if result==24:
    77                 print(i+'=24')
    78         except Exception as e:
    79             pass
    80 
    81 
    82 dian(3,9,7,8)
    穷举迭代

    结果:

     1 共1990656种
     2 ((9)+7-8)*3=24
     3 ((9+7)-8)*3=24
     4 ((9)+7-8)*3=24
     5 ((9+7)-8)*3=24
     6 (9+(7)-8)*3=24
     7 (9+(7)-8)*3=24
     8 ((9)-8+7)*3=24
     9 ((9-8)+7)*3=24
    10 ((9)-8+7)*3=24
    11 ((9-8)+7)*3=24
    12 (9-(8)+7)*3=24
    13 (9-(8)+7)*3=24
    14 ((7)+9-8)*3=24
    15 ((7+9)-8)*3=24
    16 ((7)+9-8)*3=24
    17 ((7+9)-8)*3=24
    18 (7+(9)-8)*3=24
    19 (7+(9)-8)*3=24
    20 ((7)-8+9)*3=24
    21 ((7-8)+9)*3=24
    22 ((7)-8+9)*3=24
    23 ((7-8)+9)*3=24
    24 (7-(8)+9)*3=24
    25 (7-(8)+9)*3=24
    26 共耗时14.0639998913秒
    结果

    最low也是最简单的方式,迭代了1990656种,耗时14.0639998913秒

    优化一下

     1 #coding:utf8
     2 from __future__ import division
     3 import itertools
     4 import time
     5 
     6 def dian(a,b,c,d):
     7     num_list = [str(a),str(b),str(c),str(d)]
     8     all = []
     9     #遍历所有数字组合的可能性
    10     for n in itertools.permutations(num_list,4):
    11         all.append(n)
    12 
    13     #遍历所有符号组合的可能性
    14     ops = ['+','-','*','/']
    15     ops_list = [[x,y,z] for x in ops for y in ops for z in ops]
    16 
    17     #数字和符号组合
    18     z = []
    19     for i in all:
    20         for j in ops_list:
    21             j.append('')
    22             z.append(zip(i,j))
    23 
    24     fmt = [
    25         '{A}{x}{B}{y}{C}{z}{D}',
    26         '{A}{x}(({B}{y}{C}){z}{D})',
    27         '(({A}{x}{B}){y}{C}){z}{D}',
    28         '({A}{x}{B}){y}({C}{z}{D})',
    29         '({A}{x}({B}{y}{C})){z}{D}',
    30         '{A}{x}({B}{y}({C}{z}{D}))'
    31     ]
    32 
    33     for i in z:
    34         for f in fmt:
    35             f1 = f.format(A=i[0][0],x=i[0][1],B=i[1][0],y=i[1][1],C=i[2][0],z=i[2][1],D=i[3][0])
    36             try:
    37                 if eval(f1) == 24:
    38                     print(f1+'=24')
    39             except Exception as e:
    40                 pass
    41 
    42 t1 = time.time()
    43 dian(5,6,7,8)
    44 t2 =time.time()
    45 print(t2-t1)
    优化后

    结果:

    手工列举了括号的排列方式,使得迭代的数量和循环的数量大减,迭代了9216种,耗时0.111000061035秒

     1 ((5+7)-8)*6=24
     2 (5+(7-8))*6=24
     3 (5+7)*(8-6)=24
     4 ((5-8)+7)*6=24
     5 (5-(8-7))*6=24
     6 6*((5+7)-8)=24
     7 6*(5+(7-8))=24
     8 6*((5-8)+7)=24
     9 6*(5-(8-7))=24
    10 6*((7+5)-8)=24
    11 6*(7+(5-8))=24
    12 (6/(7-5))*8=24
    13 6/((7-5)/8)=24
    14 6*((7-8)+5)=24
    15 6*(7-(8-5))=24
    16 (6*8)/(7-5)=24
    17 6*(8/(7-5))=24
    18 ((7+5)-8)*6=24
    19 (7+(5-8))*6=24
    20 (7+5)*(8-6)=24
    21 ((7-8)+5)*6=24
    22 (7-(8-5))*6=24
    23 (8-6)*(5+7)=24
    24 (8-6)*(7+5)=24
    25 (8*6)/(7-5)=24
    26 8*(6/(7-5))=24
    27 (8/(7-5))*6=24
    28 8/((7-5)/6)=24
    29 耗时0.111000061035秒
    优化后结果

     总结:

    效率不错,但是依赖语言特性,比如intertools和eval

    2、二叉树递归

  • 相关阅读:
    (转)mtr命令详解诊断网络路由
    WinDbg使用介绍
    windbg-bp、 bm、 bu、 bl、 bc、 ba(断点、硬件断点)
    【转】25.windbg-!gle、g(错误码、g系列)
    umdh windbg分析内存泄露
    windbg !logexts(自带的监控API)
    windbg cs
    windbg dds、dps、dqs
    Windbg找出memory leak的一种笨办法
    【转】windows平台多线程同步之Mutex的应用
  • 原文地址:https://www.cnblogs.com/cx59244405/p/9133531.html
Copyright © 2011-2022 走看看