解析阿里运维P7岗位面试的一道题

今年有幸同事推荐到阿里面试,岗位是流量事业部运维开始3面都很顺利评价也很高,到第四面交叉面的时候是一位P9的前辈,技术不用说了,直接是碾压我的那种,面试的时候问了一些方法论的问题,我答的不怎么样,最后他为了缓和气氛给我出了一道shell方面的题,第一个问题是如何查询文本中重复的记录,这个我答出来了,另个问题是直接给我一串字符串;例如str='ieuwugfuwgfugugfujdfjh’让我统计那个字符出现次数最多的字符,使用shell,当时一看感觉很容易不就是行转列吗,但是自己开始写的时候蒙圈了awk,sed一下子用不了拉,我想很久还是没有完成,之后我自己实现了一下,我使用2种方法:

方法一
使用shell的字符串切片处理此字符串:

[root@VM_39_7_centos ~]# str=‘ieuwugfuwgfugugfujdfjh’
[root@VM_39_7_centos ~]# for((i=0;i<${#str};i++));do echo KaTeX parse error: Expected '}', got 'EOF' at end of input: {str:i:1};done|awk '{arr[KaTeX parse error: Expected 'EOF', got '}' at position 5: 0]++}̲ END{for (i in …{#str};i++));do echo KaTeX parse error: Expected '}', got 'EOF' at end of input: {str:i:1};done|awk ‘{arr[$0]++} END{for (i in arr) print arr[i],i}’|sort -nr|head -1
6 u
[root@VM_39_7_centos ~]#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
方法二
使用sed的正则表达式匹配字符然后行转列;

[root@VM_39_7_centos ~]# echo ${str}
ieuwugfuwgfugugfujdfjh
[root@VM_39_7_centos ~]# echo ${str}|sed ‘s/([a-z]{1})/\1 \n/g’
i
e
u
w
u
g
f
u
w
g
f
u
g
u
g
f
u
j
d
f
j
h

[root@VM_39_7_centos ~]# echo ${str}|sed ‘s/([a-z]{1})/\1 \n/g’|awk ‘{arr[$0]++} END{for (i in arr) print arr[i],i}’|sort -nr|head -1
6 u
[root@VM_39_7_centos ~]#
————————————————
版权声明:本文为CSDN博主「运维打怪晋级之路」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_31555951/article/details/106596967

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值