| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 891 人关注过本帖
标题:算法求助:1231231234 --> 11353 (加加号或者乘号)
只看楼主 加入收藏
HJin
Rank: 6Rank: 6
等 级:贵宾
威 望:27
帖 子:401
专家分:0
注 册:2007-6-9
收藏
 问题点数:0 回复次数:1 
算法求助:1231231234 --> 11353 (加加号或者乘号)
Problem statment:

You are given a squence of numbers. Put + and * at appropriate places so that the math expression equals the target number. For example,

1231231234 --> 11353

12*3+1+23*123*4 = 11353 // my algorithm shows this example has a unique soln

and two more examples:

"3456237490", 1185 -> "3*4*56+2+3*7+490" // my algorithm shows this example has 3 solns
"3456237490", 9191 -> "no solution"


第三次被问到同一题目了,在面试的时候。我有一个笨的办法:search over all 3^(n-1) possible combinations, where n is the length of the sequence, and use an expression stack to evalute。Obviously, my algorithm is O(3^n), or I have exponential time complexity.

We have around 3^(n-1)choices since we can put +, *, or nothing between two digits:
1+2
1*2
12

The question is: can we have an algorithm of polynomial complexity in time?

First I thought this can be done by using some dynamic programming or greedy algorithms. But I cannot show the optimal substructure or the greedy choice property. (These concepts come from Cormen's Introduction to Algorihtms, MIT press, 2nd ed.)

Do you have any idea?

[此贴子已经被作者于2007-6-9 21:27:56编辑过]

搜索更多相关主题的帖子: 乘号 加号 算法 example 
2007-06-09 12:01
wxj120bw
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2007-6-9
收藏
得分:0 

At present,I don't have any idea.But I advise you that you express your problem in Chinese next time.

2007-06-09 13:32
快速回复:算法求助:1231231234 --> 11353 (加加号或者乘号)
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.028289 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved