题目:给定一数组 例如:a = [1,2,3,5,2,1] 现用户提供一个数字 请返回用户所提供的数字的所有下标...

 1 def test(ary):
 2         ds = {}
 3         for i in range(len(ary)):
 4                 if ds.get(ary[i]):
 5                         ds[ary[i]].append(i)
 6                 else:
 7                         ds[ary[i]] = [i]
 8         return ds
 9 
10 if __name__ == '__main__':
11         ary = [1,2,3,5,2,5,4]
12         ds = test(ary)
13         num = int(input("which number you want?"))
14         print(ds[num])

 其实字典方法和哈希方法是一样的,体现的就是一个映射关系。

将 数字和下标 的映射关系 变为     dict = { 数字:[下标,] }   的字典形式,因为一个数字对应的下标不止一个,所以下标采用列表格式。

生成字典后,就可以实现快速查询,快速地得到用户输入数字所对应的下标。

转载于:https://www.cnblogs.com/xautxuqiang/p/6422292.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值