免费注册 查看新帖 |

Chinaunix

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

[算法] 给 print 加括号 [复制链接]

求职 : 软件工程师
论坛徽章:
3
程序设计版块每日发帖之星
日期:2015-10-07 06:20:00程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2016-05-05 06:20:00
11 [报告]
发表于 2013-11-06 17:23 |只看该作者
回复 10# q1208c
  1. input     output
  2. ---------------------
  3.   a             a
  4.   'a         (quote a)
  5.   ''a        (quote (quote a))
  6.   (a b)    (a b)
  7.   '(a b)    (quote (a b))
  8.   ''(a b)   (quote (quote (a b))
复制代码

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
12 [报告]
发表于 2013-11-06 17:29 |只看该作者
还真有点麻烦,  我不太刻递归的语法了.

论坛徽章:
5
亥猪
日期:2013-10-15 13:41:04CU十二周年纪念徽章
日期:2013-10-24 15:41:34申猴
日期:2013-10-28 10:55:45辰龙
日期:2013-10-31 13:29:29丑牛
日期:2014-02-14 11:25:54
13 [报告]
发表于 2013-11-06 18:53 |只看该作者
用数组模拟栈鲁一下就行了吧

求职 : 软件工程师
论坛徽章:
3
程序设计版块每日发帖之星
日期:2015-10-07 06:20:00程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2016-05-05 06:20:00
14 [报告]
发表于 2013-11-06 19:21 |只看该作者
回复 13# lkk_super

里面有递归结构,光遍历不行。

   

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
15 [报告]
发表于 2013-11-06 19:31 |只看该作者
  1. [user@host /tmp]
  2. $ cat test.scr
  3. :test /'/{
  4.     s/'\([^']\+\)/(quote \1)/g
  5.     b test
  6. }

  7. [user@host /tmp]
  8. $ cat testfile
  9. a
  10. 'a
  11. ''a
  12. (a b)
  13. '(a b)
  14. ''(a b)

  15. [user@host /tmp]
  16. $ sed -f test.scr testfile
  17. a
  18. (quote a)
  19. (quote (quote a))
  20. (a b)
  21. (quote (a b))
  22. (quote (quote (a b)))
复制代码
perl 实在没搞出来, sed的, 凑合看看

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
16 [报告]
发表于 2013-11-06 19:37 |只看该作者
  1. [user@host /tmp]
  2. $ cat test.pl
  3. #!/usr/bin/perl
  4. #
  5. #
  6. use warnings;
  7. use strict;


  8. open(FILE, "<"."testfile") or die ("$!\n");

  9. while (my $line = <FILE>) {
  10.     chomp $line;
  11.     if ($line =~ /'/) {
  12.         $line =~ s/'([^']+)/(quote $1)/g;
  13.         redo;
  14.     } else {
  15.         print $line, "\n";
  16.     }
  17. }
  18. close(FILE);
复制代码
perl 的, 楼主试试, 土了点

求职 : 软件工程师
论坛徽章:
3
程序设计版块每日发帖之星
日期:2015-10-07 06:20:00程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2016-05-05 06:20:00
17 [报告]
发表于 2013-11-06 21:30 |只看该作者
回复 16# q1208c


    你对 sed 和 Perl 都比较熟。文本处理的功力非同一般。

    看样这样的问题要多次扫描替换,一个正则表达式很难搞定了。

    非常感谢,但我明白你的思路了。

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
18 [报告]
发表于 2013-11-07 08:07 |只看该作者
回复 17# 104359176

我也只是一般了解. 没有深入研究.

我实在不知道单一表达式是怎么搞了
   

论坛徽章:
42
19周年集字徽章-周
日期:2019-10-14 14:35:31平安夜徽章
日期:2015-12-26 00:06:30数据库技术版块每日发帖之星
日期:2015-12-01 06:20:002015亚冠之首尔
日期:2015-11-04 22:25:43IT运维版块每日发帖之星
日期:2015-08-17 06:20:00寅虎
日期:2014-06-04 16:25:27狮子座
日期:2014-05-12 11:00:00辰龙
日期:2013-12-20 17:07:19射手座
日期:2013-10-24 21:01:23CU十二周年纪念徽章
日期:2013-10-24 15:41:34IT运维版块每日发帖之星
日期:2016-01-27 06:20:0015-16赛季CBA联赛之新疆
日期:2016-06-07 14:10:01
19 [报告]
发表于 2013-11-07 09:38 |只看该作者
分行以后,等于逻辑简单了不少

求职 : 软件工程师
论坛徽章:
3
程序设计版块每日发帖之星
日期:2015-10-07 06:20:00程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2016-05-05 06:20:00
20 [报告]
发表于 2013-11-07 09:41 |只看该作者
回复 19# laputa73

是啊,实际的问题,不但没有分行,前后都有东西。
  1. (if (> 1 2) (print '(list ''(a b))))
复制代码
我只是来看看别人的思路。

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP