博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode 282. 给表达式添加运算符
阅读量:6092 次
发布时间:2019-06-20

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

给定一个仅包含0-9的字符串和一个目标值,返回在数字之间添加了二元运算符(不是一元的) +-*之后所有能得到目标值的情况。

例如:

"123", 6 -> ["1+2+3", "1*2*3"] "232", 8 -> ["2*3+2", "2+3*2"]"105", 5 -> ["1*0+5","10-5"]"00", 0 -> ["0+0", "0-0", "0*0"]"3456237490", 9191 -> []
#coding=utf-8import itertoolsimport reclass Solution(object):    def addOperators(self, num, target):        if num:            count = len(num)-1            rnum = num[-1]            s = "['','+','-','*'],"            ss = ""            for c in range(count):                ss += s            ls = []              for item in itertools.product(*eval(ss[0:-1])):                zty = ''.join(list(itertools.chain.from_iterable(zip(list(num),item))))+rnum                if eval(zty) != target or re.match(r".*([\+\-\*]0)\d.*",zty,re.M|re.I):                    continue                else:                    ls.append(zty)            return ls        return []            print Solution().addOperators("105", 5)

 

转载于:https://www.cnblogs.com/zhangtianyuan/p/8671590.html

你可能感兴趣的文章
如何使frame能居中显示
查看>>
第k小数
查看>>
构建之法阅读笔记三
查看>>
Python/PHP 远程文件/图片 下载
查看>>
【原创】一文彻底搞懂安卓WebView白名单校验
查看>>
写给对前途迷茫的朋友:五句话定会改变你的人生
查看>>
并行程序设计学习心得1——并行计算机存储
查看>>
mysql练习题40道
查看>>
JAVA入门到精通-第86讲-半双工/全双工
查看>>
bulk
查看>>
js document.activeElement 获得焦点的元素
查看>>
abb画学号
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>
day6-if,while,for的快速掌握
查看>>
JavaWeb学习笔记(十四)--JSP语法
查看>>
【算法笔记】多线程斐波那契数列
查看>>
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>