第一行输入两个正整数。
第二行输入个正整数,代表小美拿到的数组。
一个整数,代表删除的方案数。
5 2 2 5 3 4 20
4
第一个方案,删除[3]。
第二个方案,删除[4]。
第三个方案,删除[3,4]。
第四个方案,删除[2]。
n, k = map(int, input().split()) li = list(map(int, input().split())) numli = [] for x in li: t = x a = b = 0 while t % 2 == 0&nbs***bsp;t % 5 == 0: if t % 2 == 0: t //= 2 a += 1 if t % 5 == 0: b += 1 t //= 5 numli.append((a, b)) # print(numli) sm2 = [0] * (n + 1) # 求2的数量的前缀和 sm5 = [0] * (n + 1) for i in range(1, n + 1): sm2[i] = sm2[i - 1] + numli[i - 1][0] sm5[i] = sm5[i - 1] + numli[i - 1][1] # print(sm2) # print(sm5) i= 0 j = 0 res = 0 while i < n + 1: while j < n + 1: a2 = sm2[-1] - sm2[j] + sm2[i] a5 = sm5[-1] - sm5[j] + sm5[i] if min(a2, a5) < k: break j += 1 if i >= j: break res += j - 1 - i i += 1 print(res)