前言

  • 数组中判断元素是否存在的时间复杂度一般为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