|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
我们知道,列表的 index() 方法可以找到第一个匹配元素的下标,那么你有没有办法在不改变原列表的情况下,找到最后一个匹配元素的下标呢?(有两种方法可以实现)
s = [2, 2, 4, 2, 3, 6, 2]
bigger=0
temp=0
for c in s:
i = s.count(c)
if i >bigger:
bigger=i
temp=c
print(temp,'是主要元素')
这样写代码合适否,谢谢
您好!感谢您的问题。
您的代码尝试找出列表中出现次数最多的元素。虽然这种方法可以找到主要元素,但它并不是找到最后一个匹配元素的下标的方法。如果您想找到最后一个匹配元素的下标,可以使用以下两种方法:
方法一:使用循环逆序遍历列表
您可以使用循环逆序遍历列表,并使用条件语句找到第一个匹配元素的下标。以下是一个示例代码:
- s = [2, 2, 4, 2, 3, 6, 2]
- target = 2 # 要查找的元素
- index = -1 # 初始化下标为-1
- for i in range(len(s)-1, -1, -1):
- if s[ i] == target:
- index = i
- break
- print(index)
复制代码
这段代码从列表的最后一个元素开始循环逆序遍历,如果找到匹配元素,则将其下标赋值给变量index,并使用break语句跳出循环。如果循环结束后index仍然为-1,则表示未找到匹配元素。
方法二:使用rindex()方法
另一种方法是使用列表的rindex()方法,该方法可以返回最后一个匹配元素的下标。以下是一个示例代码:
- s = [2, 2, 4, 2, 3, 6, 2]
- target = 2 # 要查找的元素
- index = s[::-1].index(target) # 将列表逆序并使用rindex()方法
- print(len(s) - index - 1)
复制代码
这段代码首先使用切片将列表逆序,然后使用rindex()方法找到逆序列表中匹配元素的下标。最后,通过计算逆序下标与列表长度的差值,再减去1,即可得到原列表中最后一个匹配元素的下标。
希望以上解答对您有所帮助!如有任何疑问,请随时追问。
|
|