博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python打开转盘锁
阅读量:4035 次
发布时间:2019-05-24

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

class Solution(object):    def openLock(self,deadends,target):        numbers = [("0000",0)]        setnumbers = set()        setnumbers.add("0000")        # print(numbers[0][0][0])        while len(numbers)>0:            numberFather = numbers.pop(0)            if numberFather[0] in deadends:                return -1            if numberFather[0] == target:                return numberFather[1]            for i in range(4):                # print(numberFather[0][i])                numberT1 = (int(numberFather[0][i]) + 1)%10                numberT2 = (int(numberFather[0][i]) - 1)%10                num1 = numberFather[0][:i]+str(numberT1)+numberFather[0][i+1:]                num2 = numberFather[0][:i] + str(numberT2) + numberFather[0][i + 1:]                if (num1 not in deadends) and (num1 not in setnumbers):                    numbers.append((num1,numberFather[1]+1))                    setnumbers.add(num1)                if (num2 not in deadends) and (num2 not in setnumbers):                    numbers.append((num2,numberFather[1]+1))                    setnumbers.add(num2)        return -1"""["2110","2000","0000","2111","1110"]"0012""""if __name__ == '__main__':    s = Solution()    deadends = ["2110","2000","0000","2111","1110"]    target = "0012"    print(s.openLock(deadends,target))

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

你可能感兴趣的文章
Promise的基本使用
查看>>
android给文字加边框(修改不能居中的问题)
查看>>
coursesa课程 Python 3 programming 统计文件有多少单词
查看>>
coursesa课程 Python 3 programming 输出每一行句子的第三个单词
查看>>
coursesa课程 Python 3 programming Dictionary methods 字典的方法
查看>>
Returning a value from a function
查看>>
coursesa课程 Python 3 programming Functions can call other functions 函数调用另一个函数
查看>>
coursesa课程 Python 3 programming The while Statement
查看>>
course_2_assessment_6
查看>>
coursesa课程 Python 3 programming course_2_assessment_7 多参数函数练习题
查看>>
coursesa课程 Python 3 programming course_2_assessment_8 sorted练习题
查看>>
在unity中建立最小的shader(Minimal Shader)
查看>>
1.3 Debugging of Shaders (调试着色器)
查看>>
关于phpcms中模块_tag.class.php中的pc_tag()方法的含义
查看>>
vsftp 配置具有匿名登录也有系统用户登录,系统用户有管理权限,匿名只有下载权限。
查看>>
linux安装usb wifi接收器
查看>>
补充自动屏蔽攻击ip
查看>>
谷歌走了
查看>>
多线程使用随机函数需要注意的一点
查看>>
getpeername,getsockname
查看>>