免费注册 查看新帖 |

Chinaunix

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

[学习共享] shell 编程 [复制链接]

论坛徽章:
1
2015亚冠之山东鲁能
日期:2015-05-11 13:22:53
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-09-10 11:42 |只看该作者 |正序浏览
楼主刚刚笔试的一道题,还是想上来问问解法:

给出一个字符串:aodhpdona  判断该字符串中最先重复两次的字符,输出该字符。

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
26 [报告]
发表于 2014-09-11 09:24 |只看该作者
回复 23# ly5066113


    Tim 老师过奖了,很多都是跟您学的。

    这也是个方法:
  1. echo faohdhpna|sed 'G;:n;/^\n/d;/^\(.\).*\n.*\1/!s/\(.\)\(.*\)/\2\1/;tn;s/\(.\).*/\1/'
复制代码
回头再研究您的算法。

论坛徽章:
1
2015亚冠之山东鲁能
日期:2015-05-11 13:22:53
25 [报告]
发表于 2014-09-11 09:23 |只看该作者
回复 24# bulletmarquis

十分感谢


   

论坛徽章:
2
摩羯座
日期:2014-11-03 15:28:56卯兔
日期:2015-01-04 17:20:51
24 [报告]
发表于 2014-09-11 09:20 |只看该作者
回复 19# linux小小菜鸟


    a是数组名称,$0是数组下标,a[$0]++表示给数组赋值(awk中,如果一个变量或数组元素没有赋初值,则默认其值为0)

   比如我现在有下面这个文件
   1
    2
    1

   awk '![a$0]++'   运行的时候,逐行读取文件
   第一行读取的时候,先判断a['1'],判断是假,用!转为真,这样就可以打印这行(print语句被省略了),然后再把a['1']的值做++(由0变成1)
    第二行读取的时候,判断a['2'],处理如上
   第三行读取的时候,先判断a['1'],判断是真,用!转为假,这样就不会打印这行

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
23 [报告]
发表于 2014-09-11 09:02 |只看该作者
本帖最后由 ly5066113 于 2014-09-11 09:06 编辑

回复 16# blackold


黑哥的sed越来越炉火纯青了,算法比我的好。

精简了下我的代码:
  1. echo aodhpdona | sed -nr 'h;:a;s/(.*([^\n]).*)\2/\1\n/;ta;G;s/^([^\n]+)\n.*\n\1(.).*/\2/p'
复制代码

论坛徽章:
3
丑牛
日期:2014-09-13 18:19:22摩羯座
日期:2014-10-10 17:43:02水瓶座
日期:2014-10-16 01:00:22
22 [报告]
发表于 2014-09-10 18:03 |只看该作者
本帖最后由 李满满 于 2014-09-10 18:03 编辑

就是a[$0]默认为0,如果有一个重复的话就会a[$0]++此时就是1了,awk中大于0为真所以就会输出$0了啊,只要回复 21# linux小小菜鸟


   

论坛徽章:
1
2015亚冠之山东鲁能
日期:2015-05-11 13:22:53
21 [报告]
发表于 2014-09-10 17:55 |只看该作者
回复 20# 李满满
我不太理解这部分a[$0]++的结果是怎么得出来的?

   

论坛徽章:
3
丑牛
日期:2014-09-13 18:19:22摩羯座
日期:2014-10-10 17:43:02水瓶座
日期:2014-10-16 01:00:22
20 [报告]
发表于 2014-09-10 17:54 |只看该作者
学生党:飘过~简单模拟下flod
[yhsafe@shell ~]$ echo aodhpdona|sed -e ':a' -re 's/([[:alpha:]])([[:alpha:]])/\1\n\2/;ta'|awk 'a[$0]++{print $0;exit}'              
d

论坛徽章:
1
2015亚冠之山东鲁能
日期:2015-05-11 13:22:53
19 [报告]
发表于 2014-09-10 17:48 |只看该作者
回复 18# bulletmarquis
我一直不太清楚a[$0]++到底是什么意思?


   

论坛徽章:
2
摩羯座
日期:2014-11-03 15:28:56卯兔
日期:2015-01-04 17:20:51
18 [报告]
发表于 2014-09-10 17:20 |只看该作者
回复 4# dn833


fold确实好用
  1. echo aodhpdona|fold -1|awk 'a[$0]++{print;exit}'
复制代码
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP