百度笔试之系统设计算法题目

Pluser 2012-10-19 07:23:54
一个表达式由八个8和(,+,-,*,/,)符号组成,表达式的值为100,请设计该表达式系统,
求出所有满足的表达式:(请写算法,如写几个满足的表达式不得分) (25分)
1)数字间必须有符号,如88+8+(8+8)*8-8*8表达式就不行。
2)表达式不能相同,如8*8+(((8+8)/8)-8)*8)+8 和 8+8*8+(((8+8)/8)-8)*8)是相同的,、
即运算优先级一样。



题目大概就是这样吧,有点思路又不知从何开始。
1)想用DFS遍历这6个符号(7<=符号数<=27)再来配合数字,再来看表达式是否等于100.
2) 求表达式的值,即利用算法优先级和栈来计算,这个容易。
3)表达式是否相同,不知道弄,真心! 开始想用数据字典来保存这些表达式,再每次添加
新表达式时,来一个个判断。
4)判断方法为: 新表达式可分为几个小的表达式
如8*8+(((8+8)/8)-8)*8)+8 分为 8*8、+、(((8+8)/8)-8)*8)、+、8
在字典树中原有的表达式中一个个去除这些小式子,即表达式为空,即相同。

答题时就写了下思路,米写算法。因为根本不是一下就弄KO的! 百度的题目真XXX的难!

求大牛指点!
...全文
173 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
npuhuxl 2012-10-19
  • 打赏
  • 举报
回复
第一题应该从逆波兰式考虑
Pluser 2012-10-19
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 的回复:]
引用 3 楼 的回复:

我再顶下,这题目感觉真心难,比以前的还米想法些!
= =


求顶啊
被我发SQL版块去了 上次好像在SQL版块看见类似题目的
[/Quote]


不说了,洗澡睡觉了!
期待大牛来KO
newtee 2012-10-19
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 的回复:]

我再顶下,这题目感觉真心难,比以前的还米想法些!
= =


求顶啊
[/Quote]被我发SQL版块去了 上次好像在SQL版块看见类似题目的
Pluser 2012-10-19
  • 打赏
  • 举报
回复
我再顶下,这题目感觉真心难,比以前的还米想法些!
= =


求顶啊
newtee 2012-10-19
  • 打赏
  • 举报
回复
顶下 没人出来讨论下吗?
newtee 2012-10-19
  • 打赏
  • 举报
回复
关注下
留个沙发

64,281

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧