[luogu3941] 入阵曲
题面
话说题目前面的那首诗还挺有意境的啊哈哈.
可能今天要把中文的标点都换成英文的了, 先熟悉一下吧...
好了, 进入正题, 求一个矩阵内有多少个子矩阵满足这个子矩阵的和模k为零.看到矩阵和啊, 第一感觉就是前缀和数组,在这里便是二维前缀和, 有这样一个算式:
\]
这个算式是怎样推出来的呢, 请大家自行画图解决, 应该是很好理解的.
二维前缀和算出来了之后, 我们可以枚举x1, x2, y1, y2, 不妨令x1 <= x2, y1 <= y2, 则有这样一个算式, 矩阵和为:
\]
这样的时间复杂度为:
\]
这肯定会爆, 考虑优化, 首先, 前缀和还是要留着的, 那我们需要怎么做呢, 思考5S...
好了, 考虑压行, 我们知道两个模k同余的数相减模k必为0, 所以我们可以枚举子矩阵的上下两行或者左右两列, 在这里以上下两行为列, 从左往右枚举列, 将模k同余的数放进一个数组中保存, 每次新列加上与他同余的数的个数就是上下两行为枚举的i, j, 右边一列为枚举的k的子矩阵模k为零的个数, 好了, 具体实现在注释中会提到.
现在的时间复杂度已经被优化到了:
\]
代码实现
#include <iostream>
#include <cstdio>
using namespace std;
int n, m, K, mapp[405][405], cnt[1000005], b[405];
long long ans; //对于答案需要统计的问题, 开成longlong比较保险
inline int read()
{
int x = 0, w = 1;
char c = getchar();
while(c < '0' || c > '9') { if (c == '-') w = -1; c = getchar(); }
while(c >= '0' && c <= '9') { x = x * 10 + c - '0'; c = getchar(); }
return x * w;
}
int main()
{
// freopen("rally.in", "r", stdin);
// freopen("rally.out", "w", stdout);
n = read(); m = read(); K = read();
for(int i = 1; i <= n; i++)
for(int j = 1; j <= m; j++)
{
mapp[i][j] = read();
(mapp[i][j] += mapp[i - 1][j] + mapp[i][j - 1] + K - mapp[i - 1][j - 1]) %= K;
}
for(int i = 0; i < n; i++)
for(int j = i + 1; j <= n; j++)
{
cnt[0] = 1;//模k为0的子矩阵初始有1个, 如果第k个矩阵本身模k就为零了,减去一个空的事实上不存在的矩阵不还是等于零吗, 因为有一个前缀和, 事实上是sum[r] - sum[l - 1]嘛, 不就相当于sum[-1] % k == 0
for(int k = 1; k <= m; k++) ans += cnt[(b[k] = (mapp[j][k] - mapp[i][k] + K)) %= K]++; //b[k]统计的是第k列为右边界,第0列为左边界的子矩阵模k的值, 这样清零就只有O(m)了, 不然由于模数比较大, memset肯定会超时, 这里需要注意一下, 还有, 这个地方的写法比较玄学, 其实可以写成以下形式:
/*
for(int k = 1; k <= m; k++)
{
b[k] = (mapp[j][k] - mapp[i][k] + K) % K;
ans += cnt[b[k]];
cnt[b[k]]++;
}
*/
for(int k = 1; k <= m; k++) cnt[b[k]] = 0;
}
printf("%lld\n", ans);
return 0;
}
完
[luogu3941] 入阵曲的更多相关文章
- luogu3941入阵曲
https://www.zybuluo.com/ysner/note/1301562 题面 统计在给出的\(n*m\)矩阵中,有多少个不同的子矩形中的数字之和是\(k\)的倍数? 解析 切不掉这道题是 ...
- 【题解】入阵曲 luogu3941 前缀和 压维
丹青千秋酿,一醉解愁肠. 无悔少年枉,只愿壮志狂 题目 题目描述 小 F 很喜欢数学,但是到了高中以后数学总是考不好. 有一天,他在数学课上发起了呆:他想起了过去的一年.一年前,当他初识算法竞赛的 时 ...
- 洛谷P3941入阵曲
题目传送门 这道题也是今年湖南集训队Day8的第一题,昨天洛谷的公开赛上又考了一遍,来发个记录(其实是因为五月天,另外两道题分别是将军令和星空,出这次题目的人肯定同为五迷(✪㉨✪)) 话不多说.先理解 ...
- P3941 入阵曲
\(\color{#0066ff}{ 题目描述 }\) 小 F 很喜欢数学,但是到了高中以后数学总是考不好. 有一天,他在数学课上发起了呆:他想起了过去的一年.一年前,当他初识算法竞赛的 时候,觉得整 ...
- Luogu P3941 入阵曲【前缀和】By cellur925
题目传送门 题目大意:给你一个\(n\)*\(m\)的矩阵,每个位置都有一个数,求有多少不同的子矩阵使得矩阵内所有数的和是\(k\)的倍数. 数据范围给的非常友好233,期望得到的暴力分:75分.前1 ...
- [洛谷P3941] 入阵曲
题目背景 丹青千秋酿,一醉解愁肠. 无悔少年枉,只愿壮志狂. 入阵曲 题解在代码里. #include<iostream> #include<cstdio> #include& ...
- 落谷P3941 入阵曲
题目背景 pdf题面和大样例链接:http://pan.baidu.com/s/1cawM7c 密码:xgxv 丹青千秋酿,一醉解愁肠. 无悔少年枉,只愿壮志狂. 题目描述 小 F 很喜欢数学,但是到 ...
- 8.11 NOIP模拟测试17 入阵曲+将军令+星空
T1 入阵曲 前缀和维护可以得60分 f[x1][y1][x2][y2]=sum[x2][y2]-sum[x1-1][y2]-sum[x2][y1-1]+sum[x1-1][y1-1]; O(n4) ...
- [洛谷P3941]:入阵曲(前缀和+桶)
题目传送门 题目背景 丹青千秋酿,一醉解愁肠.无悔少年枉,只愿壮志狂. 题目描述 小$F$很喜欢数学,但是到了高中以后数学总是考不好.有一天,他在数学课上发起了呆:他想起了过去的一年.一年前,当他初识 ...
随机推荐
- 哈夫曼编码(Huffman coding)的那些事,(编码技术介绍和程序实现)
前言 哈夫曼编码(Huffman coding)是一种可变长的前缀码.哈夫曼编码使用的算法是David A. Huffman还是在MIT的学生时提出的,并且在1952年发表了名为<A Metho ...
- DICOM简介
背景: DICOM分为两大类(这里只是从DICOM相关从业者日常工作角度出发来分类的):1)DICOM医学图像处理,即DCM文件中具体数据的处理,说图像可能有些狭隘,广义上还包括波形(心电).视频(超 ...
- 弹窗中使用jquery ui的autocomplete自动完成插件无效果 实际是被遮挡了
在普通页面上使用jquery ui的autocomplete自动完成插件时正常显示提供选择的下拉框,但是放到弹窗中的时候就无法显示这个选择的下拉框,其它效果正常: 估计是被弹出窗遮挡了,网络搜索了jq ...
- 怎么配置eclipse的联想功能
第一步:打开Eclipse,windows下,打开“window”→“Preferences” :mac下,打开“偏好设置”. 第二步:选择“Java”,展开,“Editor”,选择“Content ...
- Android MVP开发模式及Retrofit + RxJava封装
代码已上传到Github,因为接口都是模拟无法进行测试,明白大概的逻辑就行了! 欢迎浏览我的博客--https://pushy.site 1. MVP模式 1.1 介绍 如果熟悉MVP模式架构的话,对 ...
- lodop 二维码内容多少
QRCode最多能放181个汉字:LODOP.ADD_PRINT_BARCODE(248,6,60,60,"QRCode","一二三四五六七八九十二二三四五六七八九十三二 ...
- 转载:http://www.cnblogs.com/double-K/p/6926367.html
sql专家感悟:不可说的感悟-——十年老技术转型(一) http://www.cnblogs.com/double-K/p/6926367.html
- 4.Servlet过滤器
1.Servlet 编写过滤器 Servlet 过滤器是可用于 Servlet 编程的 Java 类,有以下目的: 在客户端的请求访问后端资源之前,拦截这些请求. 在服务器的响应发送回客户端之前,处理 ...
- 第六章 函数、谓词、CASE表达式 6-3 CASE表达式
一.什么是CASE表达式 CASE表达式是一种运算功能,意味着CASE表达式也是函数的一种. 它是SQL中数一数二的重要功能.必须好好学习掌握. CASE表达式是在区分情况时使用的,这种情况的区分 ...
- Tomcat性能监控之Probe
目前采用java进行开发的系统居多,这些系统运行在java容器中,通过对容器的监控可以了解到java进程的运行状况,分析java程序问题.目前市面上流行的中间件有很多(Tomcat.jetty.jbo ...