问题描述
  给定一个长度为N的数列,A1, A2, ... AN,如果其中一段连续的子序列Ai, Ai+1, ... Aj(i <= j)之和是K的倍数,我们就称这个区间[i, j]是K倍区间。   你能求出数列中总共有多少个K倍区间吗?
输入格式
  第一行包含两个整数N和K。(1 <= N, K <= 100000)
  以下N行每行包含一个整数Ai。(1 <= Ai <= 100000)
输出格式
  输出一个整数,代表K倍区间的数目。
样例输入
5 2
1
2
3
4
5
样例输出
6
数据规模和约定
  峰值内存消耗(含虚拟机) < 256M
  CPU消耗 < 2000ms   请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。   注意:
  main函数需要返回0;
  只使用ANSI C/ANSI C++ 标准;
  不要调用依赖于编译环境或操作系统的特殊函数。
  所有依赖的函数必须明确地在源文件中 #include <xxx>
  不能通过工程设置而省略常用头文件。   提交程序时,注意选择所期望的语言类型和编译器类型。

枚举所有区间和,然后一一判断是否可以整除K。

区间包含的元素可以有1/2/3/4……个,包含N个元素的区间和可以在包含N-1个元素的区间和的基础上加上元素N。

通过这样的反复迭代,可以求出所有的区间和。

可是OJ只给了25分,CPU和内存都超过了限制。

import java.util.Scanner;

public class Main {

    static int N;
static int K;
static int arr[];
static int dp[][];
static int result=0; static boolean judge(int a){
if(a%K==0){
return true;
}
return false;
} public static void main(String[] args){
Scanner reader=new Scanner(System.in);
N=reader.nextInt();
K=reader.nextInt();
arr=new int[N+1];
dp=new int[N+1][N+1];
for(int i=1;i<=N;i++){
arr[i]=reader.nextInt();
dp[i][i]=arr[i];
if(judge(dp[i][i])){
result++;
}
}
int count=1;
while(count<=N-1){
for(int i=1;i<=N-count;i++){
dp[i][i+count]=dp[i][i+count-1]+arr[i+count];
if(judge(dp[i][i+count])){
result++;
}
}
count++;
}
System.out.print(result);
}
}

参考了许多人的博客,思路大都一致。

求区间 [ i , j ] 的区间和,等于 [ 1 , j ] 的区间和减去 [ 1 , i-1 ]的区间和,用 sum[j]-sum[i-1] 来表示;

当区间和对K取模等于0即 ( sum[j]-sum[i-1] )%K= 0 (  化为sum[j]%K=sum[i-1] %K )  时此区间满足条件要求。

所以对每个sum[i],求其值时顺求其对K的取模,最后得到一模数列,方便计算。

得到模数列,需选取模数列中的相同模进行组合,但题目限制了时空复杂度,此行不可行。

以题目中的第一个测试用例为例,求得模数列为 1 1 0 0 1

手动组合体验一下组合过程:

首元素 1 本身组合不了

第二个 1 可以与前面一个 1 组合

第三个元素 0 本身组合不了

第四个元素 0 可以与第三个元素 0 组合

第五个元素 1 可以与前面两个1 组合两次。(可以看出只要迭代加上前面已经出现过的相同模即可,假如存在第六个元素 1 ,此时它前面有 3 个 模 1 ,它可以与他们3个一一组合,一共在3种情况,所以加上3即可)

注意:模为0的情况,其本身不需要和其他0进行组合,因为他们不用和其他模相等(相减),自己这个数列本身就满足K倍。

Accept 代码

import java.util.Scanner;

public class Main {

    static int N;
static int K;
static int sum[];
static int mod[];
static long result=0; public static void main(String[] args){
Scanner reader=new Scanner(System.in);
N=reader.nextInt();
K=reader.nextInt();
sum=new int[N+1];
mod=new int[K];
for(int i=1;i<=N;i++){
sum[i]=(sum[i-1]+reader.nextInt())%K; //再次得到一个模 sum[i]
result+=mod[sum[i]]; //其与前面相同的模一一组合
mod[sum[i]]++;
}
System.out.print(result+mod[0]);
}
}

K倍区间 蓝桥杯的更多相关文章

  1. 2017第八届蓝桥杯 K倍区间

    标题: k倍区间 给定一个长度为N的数列,A1, A2, - AN,如果其中一段连续的子序列Ai, Ai+1, - Aj(i <= j)之和是K的倍数,我们就称这个区间[i, j]是K倍区间. ...

  2. 蓝桥杯试题 k倍区间(dp)

    问题描述 给定一个长度为N的数列,A1, A2, ... AN,如果其中一段连续的子序列Ai, Ai+1, ... Aj(i <= j)之和是K的倍数,我们就称这个区间[i, j]是K倍区间. ...

  3. 第八届蓝桥杯省赛 K倍区间

    问题描述 给定一个长度为N的数列,A1, A2, ... AN,如果其中一段连续的子序列Ai, Ai+1, ... Aj(i <= j)之和是K的倍数,我们就称这个区间[i, j]是K倍区间. ...

  4. k倍区间 前缀和【蓝桥杯2017 C/C++ B组】

    标题: k倍区间 给定一个长度为N的数列,A1, A2, ... AN,如果其中一段连续的子序列Ai, Ai+1, ... Aj(i <= j)之和是K的倍数,我们就称这个区间[i, j]是K倍 ...

  5. 蓝桥杯-k倍区间

    http://lx.lanqiao.cn/problem.page?gpid=T444 问题描述 给定一个长度为N的数列,A1, A2, ... AN,如果其中一段连续的子序列Ai, Ai+1, .. ...

  6. [蓝桥杯2017初赛]k倍区间 前缀和

    题目描述 给定一个长度为N的数列,A1, A2, ... AN. 如果其中一段连续的子序列Ai, Ai+1, ... Aj(i <= j)之和是K的倍数,我们就称这个区间[i, j]是K倍区间. ...

  7. Java实现蓝桥杯 历届试题 k倍区间

    历届试题 k倍区间 时间限制:2.0s 内存限制:256.0MB 问题描述 给定一个长度为N的数列,A1, A2, - AN,如果其中一段连续的子序列Ai, Ai+1, - Aj(i <= j) ...

  8. k倍区间:前缀和

    [蓝桥杯][2017年第八届真题]k倍区间 题目描述 给定一个长度为N的数列,A1, A2, ... AN,如果其中一段连续的子序列Ai, Ai+1, ... Aj(i <= j)之和是K的倍数 ...

  9. 【题集】k倍区间(抽屉原理)

    例1:http://lx.lanqiao.cn/problem.page?gpid=T444 蓝桥杯 问题描述 给定一个长度为N的数列,A1, A2, ... AN,如果其中一段连续的子序列Ai, A ...

随机推荐

  1. openssh 在32位、64位操作系统上的安装配置

    openssh是安装在windows系统上的提供SSH服务的服务端软件,可以提供安全的命令行远程连接管理.下面介绍下openssh成功安装使用的操作步骤. 工具/原料   openssh window ...

  2. 根据不同分辨率载入相应CSS样式表

    index.html <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http:// ...

  3. OpenLayers 3 之 切换图层控件

    OpenLayers 3 之 切换图层控件 openlayers 3中并没有默认的图层切换控件,GitHub中有一个项目实现了我们需要的控件-------- ol3-layerswitcher . 可 ...

  4. KNN笔记

    KNN笔记 先简单加载一下sklearn里的数据集,然后再来讲KNN. import numpy as np import matplotlib as mpl import matplotlib.py ...

  5. 修改SecureCRT终端的Home和End功能键。

    SecureCRT真是个不错的ssh客户端工具,但在使用时发现跟自己的一些使用习惯不符合,例如home.end.pageup.pagedown和delete等键. 默认情况下一些按键的功能如下: pa ...

  6. (一)Spring’s MVC Architecture

    Spring’s MVC module Spring’s MVC module is based on front controller design pattern followed by MVC ...

  7. Core1.1环境下,自己实现的一个简单的CRUD框架(反射实现)

    我实现了一个简单的EF框架,主要用于操纵数据库.实现了对数据库的基本操纵--CRUD 这是项目结构 这是一个 core 下的 DLL 写了一个数据库工厂,用于执行sql语句.调用sql语句工厂 写了一 ...

  8. 基于NodeJS的14款Web框架

    摘要: 在几年的时间里,Node.js逐渐发展成一个成熟的开发平台,吸引了许多开发者.有许多大型高流量网站都采用Node.js进行开发,像PayPal, 此外,开发人员还可以使用它来开发一些快速移动W ...

  9. linux进阶与hadoop

    Linux进阶命令: find .  | ls --help | more  grep ll | grep 1.txt   grep -ri  BASH 1.txt   grep -ri BASH   ...

  10. CSS选择器的匹配规则

    css选择器是从右向左匹配的, 比如:.list a {color:blue;} 先解析到 a 标签,并将页面上所有 a 标签的字体颜色都按照 color:blue 进行渲染(蓝色),再解析到 .li ...