bash shell关联数组提高查找效率

前言

  • 数组中判断元素是否存在的时间复杂度一般为O(n),是因为大家一般的做法都是遍历一遍数组看看所要找的数据是否存在。
  • 这里介绍一种利用key的唯一性来实现的时间复杂度为O(1)的判断元素是否存在的方法
  • 在c语言里这种方法经常使用,这里介绍在shell的语法中我们如何利用关联数组和key值唯一性来提高脚本的执行效率

需求&&解决方法


构建关键字数组和查找数组

#构建关键字数组
for num in `seq 1 10`
do
	element[$num]="user_"$num
done

#构建被搜索数组
for num in `seq 1 100`
do
	search[$num]="user_"$num
done


O(n2)的普通搜索

#普通的搜索方式,时间复杂度O(N2)
for e in ${element[*]}
do
	for s in ${search[*]}
	do
		if [ $e = $s ]; then
			echo "找到$e"
			break
		fi
	done
done


O(1)的关联数组搜索

#关联数组方式
declare -A newsearch

for s in ${search[*]}
do
	newsearch[$s]=1
done

#KEY值唯一性,时间复杂度O(1)
for e in ${element[*]}
do
	if [ ${newsearch[$e]} -eq 1 ]; then
		echo "找到$e"
	fi
done


shell关联数组

下标数组元素是通过数组下标(数组下标可以是算数表达式,其结果必须是一个整数)来访问的,但是这种访问方式在表达某些关联性很强的数据时会存在限制

类似于php,shell也提供了一种数组,其可以使用任意的字符串作为下标来访问数组元素,这种数组叫关联数组,关联数组也是php的精髓所在

注意,shell中定义关联数组需要声明,声明语法:
declare -A array_name


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值