描述
N个正整数,如果连续的一段(可能是一个数)和能被M整除,输出这一段的开始位置和结束位置。如果答案有多段,输出结束位置最前面的一段。
输入
第一行:2个正整数N和M,范围1<M<N<100000。
第二行:N个正整数,每个数范围[1,10000]。
输出
2个正整数。
样例输入 复制
5 6
1 2 2 2 6
样例输出 复制
2 4
提示
解释:第2个到第4个数的和是2+2+2=6
错误的分数:33
错误的代码:
#include<bits/stdc++.h>
using namespace std;
int n,m,a[100005],sum[100005];
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++)
{
cin>>a[i];
sum[i]=sum[i-1]+a[i];
}
if(m>sum[n]) printf("1 %d",n);
int s;
for(int i=1;i<=n;i++)
for(int j=i;j<=n;j++)
{
s=sum[j]-sum[i-1];
if(s%m==0)
{
printf("%d %d",i,j);
return 0;
}
}
return 0;
}