|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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,即可得到原列表中最后一个匹配元素的下标。
希望以上解答对您有所帮助!如有任何疑问,请随时追问。
|
|