题目传送门


题目背景

丹青千秋酿,一醉解愁肠。
无悔少年枉,只愿壮志狂。


题目描述

小$F$很喜欢数学,但是到了高中以后数学总是考不好。
有一天,他在数学课上发起了呆;他想起了过去的一年。一年前,当他初识算法竞赛的时候,觉得整个世界都焕然一新。这世界上怎么会有这么多奇妙的东西?曾经自己觉得难以解决的问题,被一个又一个算法轻松解决。
小$F$当时暗自觉得,与自己的幼稚相比起来,还有好多要学习的呢。
一年过去了,想想都还有点恍惚。
他至今还能记得,某天晚上听着入阵曲,激动地睡不着觉,写题写到鸡鸣时分都兴奋不已。也许,这就是热血吧。


也就是在那个时候,小$F$学会了矩阵乘法。让两个矩阵乘几次就能算出斐波那契数列的第$10^{100}$项,真是奇妙无比呢。
不过,小$F$现在可不想手算矩阵乘法——他觉得好麻烦。取而代之的,是一个简单的小问题。他写写画画,画出了一个$n\times m$的矩阵,每个格子里都有一个不超过$k$的正整数。
小$F$想问问你,这个矩阵里有多少个不同的子矩形中的数字之和是$k$的倍数?如果把一个子矩形用它的左上角和右下角描述为$(x_1,y_1,x_2,y_2)$,其中$x_1\leqslant x_2,y_1\leqslant y_2$​;那么,我们认为两个子矩形是不同的,当且仅当他们以$(x_1,y_1,x_2,y_2)$表示时不同;也就是说,只要两个矩形以$(x_1,y_1,x_2,y_2)$表示时相同,就认为这两个矩形是同一个矩形,你应该在你的答案里只算一次。


输入格式

从标准输入中读入数据。
输入第一行,包含三个正整数$n,m,k$。
输入接下来$n$行,每行包含$m$个正整数,第$i$行第$j$列表示矩阵中第$i$行第$j$列中所填的正整数$a_{i,j}$​。


输出格式

输出到标准输出中。
输入一行一个非负整数,表示你的答案。


样例

样例输入1:

2 3 2
1 2 1
2 1 2

样例输出1:

6

样例输入2:

10 10 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1 1 1

样例输出2:

3025


数据范围与提示

样例$1$说明:

这些矩形是符合要求的:
$(1,1,1,3)$,$(1,1,2,2)$,$(1,2,1,2)$,$(1,2,2,3)$,$(2,1,2,1)$,$(2,3,2,3)$。

数据范围:

子任务会给出部分测试数据的特点。如果你在解决题目中遇到了困难,可以尝试只解决一部分测试数据。
每个测试点的数据规模及特点如下表:

特殊性质:保证所有$a_{i,j}$均相同。


题解

$15\%$算法:

官方题解说是手动枚举,在此不做过多赘述。

时间复杂度:$\Theta(1)$。

期望得分:$15$分。

实际得分:$15$分。

$25\%$算法:

考虑特殊性质,可以枚举矩形的边长,然后看当前这个矩形的和是否是$k$的倍数,如果是的话$\Theta(1)$求出有多少个这样的矩形,统计答案即可。

时间复杂度:$\Theta(n\times m)$。

期望得分:$25$分。

时间得分:$30$分(撞对了一个点)。

$45\%$算法:

暴力枚举左下和右上端点,再暴力求和,比较。

时间复杂度:$\Theta(n^6)$。

期望得分:$45$分。

实际得分:$45$分。

$60\%$算法:

利用二位前缀和,让暴力球和的操作变为$\Theta(1)$。

时间复杂度:$\Theta(n^4)$。

期望得分:$60$分。

实际得分:$60$分。

$100\%$算法:

发现枚举再$ans++$肯定会超时,于是考虑不枚举。

观察到在$\mod k$意义下的前缀和,任取两个相减一定也是$k$的倍数。

于是问题转化为统计前缀和中$\equiv k$的数的对数。

直接对于每个余数统计个数即可,枚举所有连续的列压到一行处理。

时间复杂度:$\Theta(n^3)$。

期望得分:$100$分。

实际得分:$100$分。


代码时刻

$25\%$算法:

#include<bits/stdc++.h>
using namespace std;
int n,m,mod;
int Map[500][500];
long long ans;
int main()
{
scanf("%d%d%d",&n,&m,&mod);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
scanf("%d",&Map[i][j]);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
if(!((1LL*i*j*Map[i][j])%mod))
ans+=1LL*(n-i+1)*(m-j+1);
cout<<ans;
return 0;
}

$45\%$算法:

#include<bits/stdc++.h>
using namespace std;
int n,m,mod;
int Map[500][500],wzc[500],cnt[1000001];
long long ans;
int main()
{
scanf("%d%d%d",&n,&m,&mod);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
scanf("%d",&Map[i][j]);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
for(int k=i;k<=n;k++)
for(int l=j;l<=m;l++)
{
int sum=0;
for(int x=i;x<=k;x++)
for(int y=j;y<=l;y++)
sum+=Map[x][y];
if(!(sum%mod))ans++;
}
cout<<ans;
return 0;
}

$60\%$算法:

#include<bits/stdc++.h>
using namespace std;
int n,m,mod;
int Map[500][500];
int ans;
int main()
{
scanf("%d%d%d",&n,&m,&mod);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
scanf("%d",&Map[i][j]);
Map[i][j]=(Map[i][j]+Map[i-1][j]+Map[i][j-1]-Map[i-1][j-1]+mod)%mod;
}
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
for(int k=i;k<=n;k++)
for(int l=j;l<=m;l++)
if(!((Map[k][l]-Map[k][j-1]-Map[i-1][l]+Map[i-1][j-1]+mod)%mod))
ans++;
cout<<ans<<endl;
return 0;
}

$100\%$算法:

#include<bits/stdc++.h>
using namespace std;
int n,m,mod;
int Map[500][500],wzc[500],cnt[1000001];
long long ans;
int main()
{
scanf("%d%d%d",&n,&m,&mod);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
scanf("%d",&Map[i][j]);
Map[i][j]=(Map[i][j]+Map[i-1][j]+Map[i][j-1]-Map[i-1][j-1]+mod)%mod;
}
for(int i=1;i<=n;i++)
for(int j=i;j<=n;j++)
{
cnt[0]=1;
for(int k=1;k<=m;k++)ans+=cnt[(wzc[k]=Map[j][k]+mod-Map[i-1][k])%=mod]++;
for(int k=1;k<=m;k++)cnt[wzc[k]]=0;
}
cout<<ans;
return 0;
}

rp++

[洛谷P3941]:入阵曲(前缀和+桶)的更多相关文章

  1. 洛谷P3941入阵曲

    题目传送门 这道题也是今年湖南集训队Day8的第一题,昨天洛谷的公开赛上又考了一遍,来发个记录(其实是因为五月天,另外两道题分别是将军令和星空,出这次题目的人肯定同为五迷(✪㉨✪)) 话不多说.先理解 ...

  2. [洛谷P3941] 入阵曲

    题目背景 丹青千秋酿,一醉解愁肠. 无悔少年枉,只愿壮志狂. 入阵曲 题解在代码里. #include<iostream> #include<cstdio> #include& ...

  3. [luogu]P3941 入阵曲[前缀和][压行]

    [luogu]P3941 入阵曲 题目描述 小 F 很喜欢数学,但是到了高中以后数学总是考不好. 有一天,他在数学课上发起了呆:他想起了过去的一年.一年前,当他初识算法竞赛的 时候,觉得整个世界都焕然 ...

  4. 落谷P3941 入阵曲

    题目背景 pdf题面和大样例链接:http://pan.baidu.com/s/1cawM7c 密码:xgxv 丹青千秋酿,一醉解愁肠. 无悔少年枉,只愿壮志狂. 题目描述 小 F 很喜欢数学,但是到 ...

  5. 【洛谷】【前缀和+st表】P2629 好消息,坏消息

    [题目描述:] uim在公司里面当秘书,现在有n条消息要告知老板.每条消息有一个好坏度,这会影响老板的心情.告知完一条消息后,老板的心情等于之前老板的心情加上这条消息的好坏度.最开始老板的心情是0,一 ...

  6. 【洛谷 P1666】 前缀单词 (Trie)

    题目链接 考试时暴搜50分...其实看到"单词","前缀"这种字眼时就要想到\(Trie\)的,哎,我太蒻了. 以一个虚点为根,建一棵\(Trie\),然后\( ...

  7. [洛谷2671]求和<前缀和&模拟>

    题目链接:https://www.luogu.org/problemnew/show/P2671 这是noip2015普及组的第三题,谁说的普及组的题就一定水的不行,这道题就比较有意思的 这道题的暴力 ...

  8. 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP

    题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...

  9. 洛谷SP22343 NORMA2 - Norma(分治,前缀和)

    洛谷题目传送门 这题推式子恶心..... 考虑分治,每次统计跨过\(mid\)的所有区间的答案和.\(i\)从\(mid-1\)到\(l\)枚举,统计以\(i\)为左端点的所有区间. 我们先维护好\( ...

随机推荐

  1. js 动态添加Table tr,选中与不选中checkbox行数NO的变化

    首次加载进入页面,如图: 注:Table是在js中拼接字符串循环动态添加的(拼接字符串,详见之前随笔) 点击Line2 checkbox后,效果如图: 实现的效果就是: 点击checkbox — 显示 ...

  2. javascript的隐式类型转换(使(a==1&&a==2&&a==3) 成立)

    一些团队规定禁用 == 运算符换用=== 严格相等.以工程标准衡量,== 带来的便利性抵不上其带来的成本,团队协作时候你看到别人代码中的 ==,有些时候需要判断清楚作者的代码意图是确实需要转型,还是无 ...

  3. JS遍历对象和数组总结

    在日常工作过程中,我们对于javaScript遍历对象.数组的操作是十分的频繁的,今天把经常用到的方法总结一下! 一.遍历对象 1.使用Object.keys()遍历 返回一个数组,包括对象自身的(不 ...

  4. react中怎么写css样式?

    JSX基本语法中关于react如何写css样式主要有三种方法 1.基于class --(className) 基于className ,通过className在style中给该class名的DOM元素 ...

  5. 正着打星星(js)

    //让用户输入行数,使用for循环嵌套打出正着的星星来,行数等于用户输入的数字 //例如:用户输入6 // * // *** // ***** // ******* // ********* // * ...

  6. 【异常】Caused by: org.apache.phoenix.coprocessor.HashJoinCacheNotFoundException:

    1 详细异常 Caused by: org.apache.phoenix.coprocessor.HashJoinCacheNotFoundException: ERROR 900 (HJ01): H ...

  7. Spark Submit给jar包中的main函数传递参数

    1 示范 spark-submit --master xxx demo.jar "arg1" "arg2" 运行的jar包和传参放在最后,就可以了

  8. sql 脚本过大

    先把sql脚本文件中的创建部分  剪切 出来执行,创建一个数据库 然后执行cmd命令 sqlcmd   -S    CAOHONGWEI   -U   sa   -P   p@ss!123   -d  ...

  9. Matrix Factorization in RecSys

    矩阵分解在推荐系统中的应用. 参考链接:知乎. 传统SVD,Funk-SVD,Bias-SVD,SVD++. SVD奇异值分解及其意义. 漫谈奇异值分解.

  10. Java程序向MySql数据库中插入的中文数据变成了问号

    找到mysql的安装目录,修改my.ini文件 (1)如何找到my.ini文件 如果my.ini文件不在MySQL的安装目录下,可能放在隐藏目录,要先去找到ProgramData,(这里要先打开显示隐 ...