免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: fly3ds
打印 上一主题 下一主题

[算法] 怎么解析一个数学表达式 [复制链接]

论坛徽章:
1
综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00
11 [报告]
发表于 2013-10-18 15:35 |只看该作者
本帖最后由 fly3ds 于 2013-10-18 15:36 编辑

嗯   各位见识多广   方法不一   我也想出办法了   正在慢慢编   等完成了再贴程序

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
12 [报告]
发表于 2013-10-18 15:43 |只看该作者
回复 9# shan_ghost


    小心把你当病毒杀了。

论坛徽章:
7
天蝎座
日期:2013-09-28 10:45:42双子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32处女座
日期:2014-09-17 16:44:332015年亚洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16赛季CBA联赛之山东
日期:2018-03-02 23:59:31
13 [报告]
发表于 2013-10-18 17:06 |只看该作者
隐约记得大学课程<<编译原理>>有教怎么做,而且很easy。

论坛徽章:
1
综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00
14 [报告]
发表于 2013-10-18 17:07 |只看该作者
回复 13# cxytz01


第一部是把输入分成 一个个的 token

论坛徽章:
8
CU大牛徽章
日期:2013-04-17 10:59:39CU大牛徽章
日期:2013-04-17 11:01:45CU大牛徽章
日期:2013-04-17 11:02:15CU大牛徽章
日期:2013-04-17 11:02:36CU大牛徽章
日期:2013-04-17 11:02:58技术图书徽章
日期:2013-12-04 10:48:50酉鸡
日期:2014-01-03 10:32:30辰龙
日期:2014-03-06 15:04:07
15 [报告]
发表于 2013-10-18 18:39 |只看该作者
回复 12# folklore


    还好还好,用的linux,用不着傻毒软件……

论坛徽章:
8
CU大牛徽章
日期:2013-04-17 10:59:39CU大牛徽章
日期:2013-04-17 11:01:45CU大牛徽章
日期:2013-04-17 11:02:15CU大牛徽章
日期:2013-04-17 11:02:36CU大牛徽章
日期:2013-04-17 11:02:58技术图书徽章
日期:2013-12-04 10:48:50酉鸡
日期:2014-01-03 10:32:30辰龙
日期:2014-03-06 15:04:07
16 [报告]
发表于 2013-10-18 18:46 |只看该作者
主要是考虑到自己写代码解释执行速度慢而且容易出错,能支持的功能范围还很窄。丢给gcc编译,速度快,可靠,错误提示信息详尽。

而且,甚至可以在套的c函数壳外面加上#include <math.h>之类东东,直接就能在表达式中支持sqrt、sin之类数学函数;或者#include <stdlib.h>,连枚举类字符串值都能检查……可谓随心所欲,无所不能。

论坛徽章:
1
综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00
17 [报告]
发表于 2013-10-18 20:11 |只看该作者
本帖最后由 fly3ds 于 2013-10-18 21:37 编辑

https://github.com/fly3ds/linux_test

有兴趣看看这里面的expre.c,还是没有完成,不过照这个思路编下去,是没问题的。一个前提条件是输入要有空格隔开,只能认2 * 3 * 4,不能认2*3*4;

我这是野路子,只讲能完成这个任务, 不讲做的好不好完美完美, 漂亮不漂亮, 和学院派的LL LR什么的估计思路不大一样。

论坛徽章:
0
18 [报告]
发表于 2013-10-19 00:18 |只看该作者
真的是野路子。。。。

野路子的特点通常是仅能通过测试,一旦放开输入,各种莫名其妙的问题层出不穷。

论坛徽章:
1
综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00
19 [报告]
发表于 2013-10-19 00:19 |只看该作者
回复 18# sonicling

还没编完呢 ,只处理了* ,  你别指望 + - * /都给你处理了. 有兴趣自己完成.

   

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
20 [报告]
发表于 2013-10-19 01:12 |只看该作者
回复 19# fly3ds


    只处理了 * 。。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP