percy213 发表于 2023-9-1 10:03:28

课后题求助

我们知道,列表的 index() 方法可以找到第一个匹配元素的下标,那么你有没有办法在不改变原列表的情况下,找到最后一个匹配元素的下标呢?(有两种方法可以实现)

s =
bigger=0
temp=0
for c in s:
      i = s.count(c)
      if i >bigger:
         bigger=i
         temp=c
print(temp,'是主要元素')

这样写代码合适否,谢谢

isdkz 发表于 2023-9-1 10:04:11

您好!感谢您的问题。

您的代码尝试找出列表中出现次数最多的元素。虽然这种方法可以找到主要元素,但它并不是找到最后一个匹配元素的下标的方法。如果您想找到最后一个匹配元素的下标,可以使用以下两种方法:

方法一:使用循环逆序遍历列表
您可以使用循环逆序遍历列表,并使用条件语句找到第一个匹配元素的下标。以下是一个示例代码:

s =
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 =
target = 2# 要查找的元素

index = s[::-1].index(target)# 将列表逆序并使用rindex()方法

print(len(s) - index - 1)


这段代码首先使用切片将列表逆序,然后使用rindex()方法找到逆序列表中匹配元素的下标。最后,通过计算逆序下标与列表长度的差值,再减去1,即可得到原列表中最后一个匹配元素的下标。

希望以上解答对您有所帮助!如有任何疑问,请随时追问。
页: [1]
查看完整版本: 课后题求助