微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在我的列表中找到重复项,稍后在代码中使用它

如何解决在我的列表中找到重复项,稍后在代码中使用它

嗨,我正在尝试编写一个代码来检查我的列表中的重复项。我想稍后在程序中使用这个副本(它用于拼图,有两个是拼图的正确答案)。 我希望将“重复”存储在“i”中 - 这样我就可以做类似的事情 如果 i = RGB_orange - 这样做或那样做。举个例子

我尝试了很多不同的东西。这是我得到的最接近的。任何帮助表示赞赏。
顺便说一句 - 该列表的内容是不同的 RGB 值。 coordiantes 是另一个列表,它是我的程序获取其 RGB 值的地方。

    for x in coordinates:
            rgbvalue = Tappair.getpixel(x)

#            rgblist = [(94,197,189),## just an example
#                   (127,176,254),#                   (233,131,78),#                   (239,106,253),#                   (225,81,99),#                   (126,230,129),#                   (139,33,200)]

            rgblist = []


            rgblist.append(rgbvalue)
            print(rgblist)
            for i in rgblist:
                if rgblist.count(i) == 2:
                    print(i)
                    print("Counted")
                    print(rgblist)
                    break

编辑:这有效:

def tap_the_pair():
if pyautogui.locateCenterOnScreen('TapPair.png',confidence=0.9,region=(689,250,640,1000)) != None:
    Tappair = pyautogui.screenshot(region=(734,429,540,540))
    Tappair.save(r"C:\Users\Andreas\Desktop\pythonProject\WholeTapPair.png")
    print("tap pair game found")

    rgblist = []

   # rgblist.append(rgbvalue)

    rgb_dict = {}

    for x in coordinates:
        rgbvalue = Tappair.getpixel(x)
        if rgbvalue in rgb_dict:
            print(rgbvalue)
            return rgbvalue
        else:
            rgb_dict[rgbvalue] = True

解决方法

您可以使用以下命令查找列表中的重复项:

import collections

rgblist = [(94,197,189),(127,176,254),(233,131,78),(239,106,253),(225,81,99),(126,230,129),(139,33,200)]

duplicates = [item for item,count in collections.Counter(rgblist).items() if count > 1]

print(duplicates)

for i in duplicates:
    # Do something with each duplicate

输出:

[(233,78)]     
,

问题中提供的解决方案也有效,但它的时间复杂度为 O(n^2)。具有更好时间复杂度的更好方法是使用字典:

rgb_dict = {}

for rgb in rgblist:
    if rgb in rgb_dict:
        print(rgb)
        break
    else:
        rgb_dict[rgb] = True

循环结束后,rgb 将包含重复项。该解决方案的时间复杂度为 O(n)。

编辑:尝试使用特定于您的示例的代码。它可以使用单个 for 循环来完成

rgb_dict = {}

for x in coordinates:
    rgbvalue = Tappair.getpixel(x)
    if rgbvalue in rgb_dict:
        print(rgbvalue)
        return rgbvalue
    else:
         rgb_dict[rgbvalue] = True

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。