Python 如何降低执行此三重计数函数所需的复杂性/时间?

Python 如何降低执行此三重计数函数所需的复杂性/时间?,python,dictionary,hashtable,Python,Dictionary,Hashtable,目前想知道如何降低这个三重计数函数的复杂性/时间 这个解决方案是可行的,但它太慢,无法传递给HackerRank def count_triplets(arr, r): left_map = {} right_map = {} for item in arr: right_map[item] = arr.count(item) # store frequency of occurences of each item. count = 0

目前想知道如何降低这个三重计数函数的复杂性/时间

这个解决方案是可行的,但它太慢,无法传递给HackerRank

def count_triplets(arr, r):
    left_map = {}
    right_map = {}
    for item in arr:
        right_map[item] = arr.count(item)  # store frequency of occurences of each item.

    count = 0
    for i in range(0, len(arr)):
        mid_term = arr[i]
        c1 = 0
        c3 = 0
        right_map[mid_term] -= 1
        left_term = mid_term / r
        if left_term in left_map and mid_term % r == 0:
            c1 = left_map.get(left_term)

        right_term = mid_term * r
        if right_term in right_map:
            c3 = right_map.get(right_term)

        count += c1 * c3

        if mid_term in left_map:
            left_map[mid_term] += 1
        else: 
            left_map[mid_term] = 1

    return count


if __name__ == '__main__':
    r = 3
    arr = [1,3,9,9,9,27,81]  # returns 9 as solution
    # arr = [1,3,9,9,27,81] # returns 6 as solution
    result = count_triplets(arr, r)
    print("result = ", result)
此代码:

    right_map = {}
    for item in arr:
        right_map[item] = arr.count(item)  # store frequency of occurences of each item.
是O(n^2)复杂度,因为
arr.count
本身就是O(n),这可能是您的问题。您可以使用
计数器对
O(n)
中的所有项目进行计数,这也有助于简化您的代码:

from collections import Counter


def count_triplets(arr, r):
    left_map = Counter()
    right_map = Counter(arr)

    count = 0
    for mid_term in arr:
        right_map[mid_term] -= 1
        if mid_term % r == 0:
            left_term = mid_term / r
            c1 = left_map[left_term]
        else:
            c1 = 0

        right_term = mid_term * r
        c3 = right_map[right_term]

        count += c1 * c3
        left_map[mid_term] += 1

    return count


def test():
    r = 3
    assert count_triplets([1, 3, 9, 9, 9, 27, 81], r) == 9
    assert count_triplets([1, 3, 9, 9, 27, 81], r) == 6


if __name__ == '__main__':
    test()

你可以在codereview.stackexchange.com上找到更好的答案