k倍区间-蓝桥杯

2017省赛蓝桥杯k倍区间python

在这里插入图片描述
在这里插入图片描述

最近在准备蓝桥杯,有个寒假刷题,自己写了个超时了,然后又找了找,终于找到一个没超时的。改成python代码后,看了半天没看懂,然后又去翻了翻,看了别人的评论终于弄懂了。写个博客记录一下。

思路大概就是:先算前n项和,并记录余数。然后现在从第一项开始的k倍区间都已经计数了,接着要算从第k项开始的k倍区间(1<k<=n)。k倍区间的余数必须是0,下面就要算前k个区间减去前面第j个区间的和为0的个数(1<=j<k)。因为区间是连续的,所以他们的余数必须相等。也就是count=count+ C i 2 C_i^2 Ci2,i为余数相等的个数。
即代码里的count=count+flag[i]*(flag[i]-1)/2

import os
import sys
n,k=input().split()
n=int(n)
k=int(k)
flag=[0 for i  in range(1000000)]
x=[]
count=0
x.append(int(input()))
x[0]=x[0]%k
if x[0]==0:
    count += 1
flag[x[0]]=flag[x[0]]+1
for i in range(1,n):
    a=int(input())
    x.append((a%k+x[i-1])%k)
    flag[x[i]]=flag[x[i]]+1
    if x[i]==0:
        count += 1
for i in range(k):
    count=count+flag[i]*(flag[i]-1)/2
print(int(count))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值