当前位置: 首页 > news >正文

儿童网站源码两学一做网站源码

儿童网站源码,两学一做网站源码,相册网站怎么做,沈阳妇科体检去哪里好✍个人博客:https://blog.csdn.net/Newin2020?spm1011.2415.3001.5343 📚专栏地址:蓝桥杯题解集合 📝原题地址:K 倍区间 📣专栏定位:为想参加蓝桥杯的小伙伴整理常考算法题解,祝大家…

✍个人博客:https://blog.csdn.net/Newin2020?spm=1011.2415.3001.5343
📚专栏地址:蓝桥杯题解集合
📝原题地址:K 倍区间
📣专栏定位:为想参加蓝桥杯的小伙伴整理常考算法题解,祝大家都能取得理想成绩!
❤️如果有收获的话,欢迎点赞👍收藏📁,您的支持就是我创作的最大动力💪

问题描述

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

你能求出数列中总共有多少个 K 倍区间吗?

输入格式

第一行包含两个整数 N 和 K。

以下 N 行每行包含一个整数 Ai。

输出格式

输出一个整数,代表 K 倍区间的数目。

数据范围

1≤N,K≤100000,
1≤Ai≤100000

输入样例:

5 2
1
2
3
4
5

输出样例:

6

思路

这道题涉及到了区间和的计算,所以可以用前缀和的思想来做。

首先,先对传入的区间求一遍前缀和,然后再去遍历每个区间来判断该区间和是否满足 K 的倍数。

就拿题目样例举例,我们看其中一个区间 [2,4],可以直接利用前缀和数组计算出该区间的和,然后判断是否为 K 的倍数,可以发现该区间和为 15 - 3 = 12,且 k = 2 故满足 K 的倍数,答案加一。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HjRDhtus-1677288292090)(AcWing 蓝桥杯辅导.assets/5-2.png)]

我们在此基础上优化一下,可以用空间换时间,通过题目可以知道区间 [l , r] 的和是 k 的倍数即 (sum[r]−sum[l−1])%k==0(sum[r] - sum[l-1]) \% k == 0(sum[r]sum[l1])%k==0,可以推出 sum[r]%k==sum[l−1]%ksum[r] \% k == sum [l-1] \% ksum[r]%k==sum[l1]%k

再解释下 ans+=res[sum[i]]ans += res[sum[i]]ans+=res[sum[i]]

首先明确 res[sum[i]]res[sum[i]]res[sum[i]] 表示的是 sum[i]sum[i]sum[i] 出现过的次数。

举个例子,假设 sum[i]=3sum[i] = 3sum[i]=3,在后边的循环中,又出现了一个 sum[i]=3sum[i] = 3sum[i]=3,那么此时,这个 “3” 可以和前边出现过的所有的 “3” 分别构成一个 K 倍区间,前边的 “3” 一共出现过 res[sum[i]]res[sum[i]]res[sum[i]] 次,所以此时又新增了res[sum[i]]res[sum[i]]res[sum[i]] 个 K 倍区间。

代码

前缀和
#include <bits/stdc++.h>
using namespace std;int n, k;
const int N = 100010;
int s[N];int main() {scanf("%d%d", &n, &k);//计算前缀和for (int i = 1; i <= n; i++) {scanf("%d", &s[i]);s[i] += s[i - 1];}//枚举每个区间,判断其和是否为K的倍数int res = 0;for (int l = 1; l <= n; l++)for (int r = l; r <= n; r++)if ((s[r] - s[l - 1]) % k == 0)res++;cout << res << endl;return 0;
}
前缀和(优化)
#include <bits/stdc++.h>
using namespace std;int n, k;
const int N = 100010;
typedef long long LL;
int sum[N], a[N];   //一个储存前缀和,一个储存余数int main() {scanf("%d%d", &n, &k);LL res = 0;for (int i = 1; i <= n; i++) {scanf("%d", &sum[i]);sum[i] = (sum[i] + sum[i - 1]) % k; //求前缀和的余数res += a[sum[i]]; //计算可以匹配两两区间结合的数量a[sum[i]]++;}//这里还要加a[0]是因为之前加的是两两区间结合算一次//而余数为0是个特殊值,它可以单独算一个,因此要算上余数为0的区间自身cout << res + a[0] << endl; return 0;
}
http://www.yayakq.cn/news/398386/

相关文章:

  • 购物网站建设需要注意什么建立个人网页
  • 微信网站和手机网站的区别网络维护专业
  • 做电商网站前端用什么框架单位网站建设费用账务处理
  • 中小型网站建设信息济南智能网站建设
  • 网站建设改版升级网站设计师的专业知识
  • 专业网络推广平台百度竞价关键词优化
  • 论坛网站开发中遇到的问题互联网怎么赚钱
  • 餐饮加盟手机网站建设手机系统
  • 网站建设制作优帮云网站如何做防护
  • 福州做网站多少钱网站推广优化方法
  • 学习教建网站seo技术蜘蛛屯
  • 网站建设培训视频推销产品的万能句子
  • 网站建设要做些什么问题wordpress主题的安装
  • 主页网站建设如何查询logo是否已经被注册
  • 网站站外优化推广方式松江区网站建设公司
  • 网站建设产品服务实创装饰官网
  • 展示图片的网站模板wordpress发不了博文
  • 网站蜘蛛爬行统计自己的主机做服务器网站如何备案
  • 广州购物商城网站开发二次开发比一次开发难吗
  • 网站后台更新怎么做南京创网网络技术有限公司
  • 网站建设课程设计报告范文wordpress 官方文档
  • 班组安全建设 网站制作企业网站得多长时间
  • 做的最好的紫砂网站小米手机网站建设总结
  • 投资网站建设公司医院网站建设报告
  • 无锡网站 app微信小程序开发需要多少钱?
  • 网站ip地址 转向域名中国手工加工网免费供料
  • 庐阳网站快速排名wordpress 存储插件
  • 网站搜索不到了晋江企业网站开发
  • 网站如何被谷歌收录一个空间做2个网站
  • 建手机号码的网站vi设计找哪家公司