首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >添加+/-以使数值字符串的计算结果为0

添加+/-以使数值字符串的计算结果为0
EN

Stack Overflow用户
提问于 2012-10-18 14:11:21
回答 2查看 70关注 0票数 1

给定一个由数字组成的字符串,添加+或-号以使表达式值为0。返回表达式。

例如,

123 => 1+2 -3 =0

173956 => 17 + 39 - 56 =0

除了暴力破解之外,我没有任何线索来解决这个问题。

有什么建议吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-10-18 14:22:28

这是一个搜索问题。搜索必须在解空间中执行。假设我们从'123‘字符串开始,此时,我们可以在'1’后面加上+或-号,结果我们得到了'1 + 23‘或'1 - 23’。每个变体都可以通过在下一个字符后面添加一个符号来进一步拆分。因此,所有可能的符号加法都将形成树状结构--解空间。您的算法必须在此结构中搜索解决方案。我认为A*可以用来做这件事。

Anders K绘制了很好的解空间的ASCII图,你只需要搜索它的解。简单的广度优先搜索或深度优先搜索可以完成这项工作,但如果解空间很大,我认为它会很慢。

此外,我认为有可能找到更优化,更具体的解决方案,利用解决方案空间的属性,例如-它的树状结构。

票数 1
EN

Stack Overflow用户

发布于 2012-10-18 14:21:51

你可以用很多方法来解决它,例如,使用递归方法,如果你把它构造成一个树,这一点就会变得很明显

例如123

由于数字(+|-)后面可能有两个不同的符号:

代码语言:javascript
复制
        1
       / \
      +   -
     /     \
    2       2   
   / \     / \
  +   -   +   -
  |   |   |   |
  3   3   3   3
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12948159

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档