Vijos 1090题:连续数之和
来源:互联网 发布:汤臣倍健褪黑素片 知乎 编辑:程序博客网 时间:2024/06/05 18:01
描述
有n个正整数排成一行。你的目的是要从中取出一个或连续的若干个数,使它们的和能够被k整除。
例如,有6个正整数,它们依次为1、2、6、3、7、4。若k=3,则你可以取出1、2、6,或者2、6、3、7,也可以仅仅取出一个6或者3使你所取的数之和能被3整除。当然,满足要求的取法不止以上这4种。事实上,一共有7种取法满足要求。
给定n和k,以及这n个数。你的任务就是确定,从这n个数中取出其中一个数或者若干连续的数使它们的和能被k整除有多少方法。
由于取法可能很多,因此你只需要输出它mod 1234567的值即可。
格式
输入格式
第一行有两个正整数,分别代表n和k。输入数据保证有n<=500 000,k<=100 000。
以下n行每行一个正整数。这些正整数保证都不大于10 000。
输出格式
一个正整数。它应该是你的答案mod 1234567的结果。
样例1
样例输入1
6 3
1
2
6
3
7
4
样例输出1
7
限制
各个测试点1s
#include<iostream>using namespace std;int a[100001];int main(){ std::ios::sync_with_stdio(false); int n, k, ans = 0, x, y = 0; cin >> n >> k; for (int i = 0;i < n;i++) { cin >> x; y = (x + y) % k; ans += a[y]; if (y == 0)ans++; ans %= 1234567; a[y]++; } cout << ans << endl; return 0;}
1 0
- Vijos 1090题:连续数之和
- vijos连续数之和
- Vijos P1090连续数之和
- #Vijos P1090#连续数之和
- Vijos 连续数之和 (组合数学)
- Vijos1090. 连续数之和
- 前缀和(vijos1090连续数之和)
- 【剑指offer】题41:和为s的两个数VS连续正整数之和为S
- Vijos 1304题:回文数
- 连续数之和为x,求共有几对
- python_lintcode_397最长上升连续子序列_56两数之和
- LightOJ 1278 一个固定数可以换为几个连续数之和 求这样的连续数有多少对
- Vijos 1117题:数的划分
- Vijos 1130题:数的计数
- Vijos 1772题:巧妙填数
- Vijos 1696题:数与连分数
- Vijos 1335题:数独验证
- 计算一串连续数组的之间 连续几个数(任意连续)之和的最大值 Microsoft Visual Studio
- 20170427
- jade---模板项目
- [译]Scaling in the Linux Networking Stack: XPS
- eclipse如何删除空行
- js删除对象的属性及封装方法
- Vijos 1090题:连续数之和
- Oracle部分语句
- iOS开发-二维码扫描和应用跳转
- 30分钟LINQ教程
- 解决/usr/lib/libstdc++.so.6: version `GLIBCXX_3.4.14' not found问题
- QSKJ面试
- 找出二叉树中指定结点的下一个结点(中序后继)可以假定每个结点都有指向父节点的连接
- 二分贪心--24
- Android Accessibility 安全性研究报告