免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12345下一页
最近访问板块 发新帖
查看: 8103 | 回复: 49
打印 上一主题 下一主题

各位大虾,小弟有难啊! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-12-20 13:08 |只看该作者 |倒序浏览
我想对一个带括号的字符串解析,可是总得不到想要的结果:

t  = (A interact  ((B  or  C)  or (((D inside E) or F)  inside G)))

我想要的结果为:
t0 =  A_B
t1 =  A_C
t2 =  A_D_E_G
t3 =  A_F_G
(遇到interact/inside用"_"将两个变量变成一个变量,并参与后续运算;遇到or就将两个变量分别参与后续运算)

谢谢各位!!!

论坛徽章:
0
2 [报告]
发表于 2013-12-20 15:21 |只看该作者
自己顶一下!

论坛徽章:
5
丑牛
日期:2014-01-21 08:26:26卯兔
日期:2014-03-11 06:37:43天秤座
日期:2014-03-25 08:52:52寅虎
日期:2014-04-19 11:39:48午马
日期:2014-08-06 03:56:58
3 [报告]
发表于 2013-12-20 17:46 |只看该作者
这个问题太难,
没有人知道,{:2_171:}

论坛徽章:
0
4 [报告]
发表于 2013-12-22 16:38 |只看该作者
真是悲催阿!!!!{:2_175:}

论坛徽章:
5
丑牛
日期:2014-01-21 08:26:26卯兔
日期:2014-03-11 06:37:43天秤座
日期:2014-03-25 08:52:52寅虎
日期:2014-04-19 11:39:48午马
日期:2014-08-06 03:56:58
5 [报告]
发表于 2013-12-22 17:21 |只看该作者
{:2_167:} 小伙伴们, 这个问题超难!
回复 4# yuanquan08


   

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
6 [报告]
发表于 2013-12-22 20:54 |只看该作者
先把你这个字符串转换成结构化的数据,再想办法找出所有组合。

第一步即使不会用正则表达式的方法也可以先分割字符,再用栈组合起来。

第二步就是个递归。

论坛徽章:
0
7 [报告]
发表于 2013-12-22 22:11 |只看该作者
感觉这些东西像是布尔网络、人工智能有关,是不是有专业软件可以用哈?

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
8 [报告]
发表于 2013-12-23 00:20 |只看该作者
本帖最后由 rubyish 于 2013-12-23 03:05 编辑

biru:
  1. #!/usr/bin/perl

  2. sub Or { @_ }

  3. sub In {
  4.     map join( '_', split /\|/ ),
  5.     glob '{' . join( '}{', map join( '|,', @$_ ) . '|', @_ ) . '}';
  6. }

  7. sub Which { shift eq 'or' }

  8. sub From {
  9.     map { s/(\w+)/'$1',/g; s/\(/[/g; s/\)/],/g; eval } shift
  10. }

  11. sub Extract {
  12.     my ( $Operator, @Operand ) = @{ +shift }[ 1, 0, 2 ];
  13.     Which($Operator) ?
  14.     Or  map { ref $_ ?   Extract($_)   :  $_  } @Operand :
  15.     In  map { ref $_ ? [ Extract($_) ] : [$_] } @Operand
  16. }



  17. my $String  = <DATA>;
  18. my @Result  = Extract From $String;
  19. print $_ . $/ for @Result;

  20. __DATA__
  21. (A interact  ((B  or  C)  or (((D inside E) or F)  inside G)))
复制代码

论坛徽章:
0
9 [报告]
发表于 2013-12-23 01:34 |只看该作者
本帖最后由 felonwan 于 2013-12-23 01:50 编辑

楼上牛!

这好像是一个加法和乘法的分配律、结合律问题,只含加法和乘法的多项式展开。。。
直接替换“interact”及“inside”为“*”,替换“or”为“+”,然后放到符号计算工具里一算,结果里的各项就是楼主要的各项。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
10 [报告]
发表于 2013-12-23 09:29 |只看该作者
回复 9# felonwan


    对头,就是个多项式展开。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP