如何找出列表中相同元素的所有索引值 python实现

如何找出列表中相同元素的所有索引值 python实现,第1张

如何找出列表中相同元素的所有索引值 python实现

index()只能找到第一个索引位置,那么如何找到相同元素的所有索引值呢?
可以通过以下方式实现:

nums = [2,5,5,11]
# 找出元素值为5的索引
index = [i for i,val in enumerate(nums) if val==5]
两数之和:

方法一:
def twoSum(nums, target):
	nums1 = sorted(nums)
	left,right = 0,n-1
	res = []
	while left<right:
		if nums1[left]+nums1[right]==target:
			# 由于只有一种答案,那么可以确定的是,最多只有两个相同的元素
			if nums1[left]==nums1[right]:
				index = [i for i ,val in enumerate(nums) if val==nums1[left]]
				return index
			else:
				res.append(nums.index(nums1[left]))
				res.append(nums.index(nums1[right]))
				return res
		elif nums1[left]+nums1[right]<target:
			left+=1
		else:
			right-=1
方法二:
def twoSum(nums,target):
	for i in range(len(nums)):
        res = []
        temp = nums[:i]
        if target-nums[i] in temp:
            index = nums.index(target-nums[i])
            res.append(i)
            res.append(index)
            return res

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/719125.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-25
下一篇 2022-04-25

发表评论

登录后才能评论

评论列表(0条)

保存