- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
所以我有一个包含一些值的列表,例如[230, 67, 34, 60, 2, 10]
和操作列表 [operations.add, operations.sub, operations.mul, operations.div]
和一个 result number
,这是我事先知道的。
找到所有可能给出结果的数学表达式的最佳方法是什么。
例如,如果结果是 154
,一种可能的解决方案是 60*2+34
。
我在设计这个算法时遇到的问题是,因为我事先不知道表达式将使用哪些值和操作,哪些不会,或者可能全部使用。
如果您能提供一些 python 代码,将不胜感激。
提前致谢
最佳答案
您可以创建一个代表所有可能组合的树,其中一个节点代表一个数字或一个运算符。然后通过对结果树进行DFS或BFS,可以找到所有的Node,使得从根到Node的路径所表示的表达式计算出想要的值。这是 Python 中的代码:
class Node():
def __init__(self, type, val, parent, children):
self.type = type
self.value = val
self.parent = parent
self.children = children
self.total = None
def expandBranch(node, numList, opList):
if len(numList) == 0:
return
if node.type == "Operator" or node.type is None:
for i in range(len(numList)):
newList = numList[:]
num = newList.pop(i)
newNode = Node("Number", num, node, [])
node.children.append(newNode)
expandBranch(newNode, newList, opList)
else:
for op in opList:
newNode = Node("Operator", op, node, [])
node.children.append(newNode)
expandBranch(newNode, numList, opList)
def dfs(node, result):
if len(node.children) == 0:
return
if node.type == "Number":
if node.parent.type == None:
node.total = node.value
elif node.parent.value == "+":
node.total = node.parent.total + node.value
elif node.parent.value == "-":
node.total = node.parent.total - node.value
elif node.parent.value == "*":
node.total = node.parent.total * node.value
elif node.parent.value == "/":
node.total = node.parent.total / node.value
else:
pass # should never come here
if node.total == result:
output = []
while node.parent is not None:
output.insert(0, node.value)
node = node.parent
print(output)
return
elif node.type == "Operator":
node.total = node.parent.total
else:
pass # root node, nothing to do
for child in node.children:
dfs(child, result)
def main():
nums = [230, 67, 34, 60, 2, 10]
ops = ["+", "-", "*", "/"]
root = Node(None, None, None, [])
expandBranch(root, nums, ops)
dfs(root, 154)
if __name__ == "__main__":
main()
给出输出:
[230, '+', 10, '/', 2, '+', 34]
[67, '+', 10, '*', 2]
[67, '*', 10, '/', 230, '*', 60, '+', 34]
[67, '/', 230, '+', 60, '*', 2, '+', 34]
[67, '/', 230, '+', 2, '*', 60, '+', 34]
[34, '-', 67, '*', 2, '+', 230, '-', 10]
[34, '-', 67, '*', 2, '-', 10, '+', 230]
[34, '-', 2, '*', 67, '/', 10, '-', 60]
[34, '/', 230, '+', 67, '+', 10, '*', 2]
[34, '/', 230, '+', 10, '+', 67, '*', 2]
[34, '/', 60, '+', 67, '+', 10, '*', 2]
[34, '/', 60, '+', 10, '+', 67, '*', 2]
[34, '/', 2, '+', 67, '+', 60, '+', 10]
[34, '/', 2, '+', 67, '+', 10, '+', 60]
[34, '/', 2, '+', 60, '+', 67, '+', 10]
[34, '/', 2, '+', 60, '+', 10, '+', 67]
[34, '/', 2, '+', 10, '+', 67, '+', 60]
[34, '/', 2, '+', 10, '+', 60, '+', 67]
[60, '*', 2, '+', 34]
[60, '/', 230, '+', 67, '+', 10, '*', 2]
[60, '/', 230, '+', 10, '+', 67, '*', 2]
[60, '/', 34, '+', 230, '-', 67, '-', 10]
[60, '/', 34, '+', 230, '-', 10, '-', 67]
[60, '/', 34, '-', 67, '+', 230, '-', 10]
[60, '/', 34, '-', 67, '-', 10, '+', 230]
[60, '/', 34, '-', 10, '+', 230, '-', 67]
[60, '/', 34, '-', 10, '-', 67, '+', 230]
[60, '/', 34, '*', 67, '+', 10, '*', 2]
[60, '/', 34, '*', 10, '+', 67, '*', 2]
[2, '*', 60, '+', 34]
[10, '+', 230, '/', 2, '+', 34]
[10, '+', 67, '*', 2]
[10, '*', 67, '/', 230, '*', 60, '+', 34]
[10, '/', 230, '+', 60, '*', 2, '+', 34]
[10, '/', 230, '+', 2, '*', 60, '+', 34]
[10, '/', 67, '+', 60, '*', 2, '+', 34]
[10, '/', 67, '+', 2, '*', 60, '+', 34]
代码比较粗糙,有待改进。请注意,整数除法将出现在代码中。另请注意,当您向原始列表中添加更多数字时,程序会呈指数级变慢。
关于python - 查找(或暴力破解)值列表和数学运算的数学表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43928596/
用户将输入重量阈值、物体数量以及 3 个物体的重量和成本。输出应该是背包图,并且应该显示最优解。 重量应该最大,成本应该最小。 示例输出: w=60 n=3 w = 10 w2 = 35 w3 = 3
所以我在学习 Python 的同时从“Violent Python”开始黑客攻击,我遇到了一个问题这是我的代码: import optparse import socket from socket i
我是一名优秀的程序员,十分优秀!