HDU 6336.Problem E. Matrix from Arrays-子矩阵求和+规律+二维前缀和 (2018 Multi-University Training Contest 4 1005)
2024-10-22 08:44:10
6336.Problem E. Matrix from Arrays
不想解释了,直接官方题解:
队友写了博客,我是水的他的代码
------>HDU 6336 子矩阵求和
至于为什么是4倍的,因为这个矩阵是左上半边有数,所以开4倍才能保证求的矩阵区域里面有数,就是图上的红色阴影部分,蓝色为待求解矩阵。
其他的就是容斥原理用一下,其他的就没什么了。
代码:
//1005-6336-矩阵求和-二维前缀和+容斥-预处理O(1)查询输出
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<bitset>
#include<cassert>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<ctime>
#include<deque>
#include<iomanip>
#include<list>
#include<map>
#include<queue>
#include<set>
#include<stack>
#include<vector>
using namespace std;
typedef long long ll; const double PI=acos(-1.0);
const double eps=1e-;
const ll mod=1e9+;
const int inf=0x3f3f3f3f;
const int maxn=+;
#define ios ios::sync_with_stdio(false);cin.tie(0);cout.tie(0); ll n,a[maxn],sum[maxn][maxn]; void init()
{
int cnt=;
for(int i=;i<*n;++i){
for(int j=;j<=i;++j){
sum[j][i-j]=a[cnt];
cnt=(cnt+)%n;
}
}
for(int i=;i<*n;i++){
for(int j=;j<*n;j++){
if(i> &&j> ) sum[i][j]+=sum[i-][j]+sum[i][j-]-sum[i-][j-];
if(i==&&j> ) sum[i][j]+=sum[i][j-];
if(i> &&j==) sum[i][j]+=sum[i-][j];
}
}
} ll GetAns(int x,int y)
{
ll ans=;
ans+=(x/n)*(y/n)*sum[n-][n-];
ans+=(y/n)*sum[x%n][n-];
ans+=(x/n)*sum[n-][y%n];
ans+=sum[x%n][y%n];
return ans;
} int main()
{
int t;scanf("%d",&t);
while(t--){
scanf("%lld",&n);
for(int i=;i<n;i++)
scanf("%lld",&a[i]);
init();
n=n*;
int m;scanf("%d",&m);
for(int i=;i<m;i++){
int x1,y1,x2,y2;
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
ll ans=GetAns(x2,y2)-GetAns(x1-,y2)-GetAns(x2,y1-)+GetAns(x1-,y1-);//容斥
printf("%lld\n",ans);
}
}
}
溜了。
最新文章
- Android请求网络共通类——Hi_博客 Android App 开发笔记
- Spring+EhCache缓存实例
- document.execCommand 常用的方法
- s3c2440 移值u-boot-2016.03 第1篇 新建单板
- 利用js排序html表格
- MSSQLServer基础06(变量,case,选择语句)
- 从NIB中加载VIEW
- IE8下的项目在IE11下某些功能无法实现的问题
- QT中的qmake详解
- wrapper x64 版本发布到centos
- Sublime Text3时间戳查看转换插件的开发
- 微信小程序自定义导航栏
- 编写函数求整形数组a中存储的m个不重复的整数的第k大的整数(其中m>;=1,1<;=k<;=m)很简单的一个思路是酱紫的:管他辣么多干啥,上来一把排序然后直接得答案
- sublime text 3中安装ctags支持函数跳转,安装convertToUtf8支持中文步骤[工具篇]
- armv8 memory system
- Java - 21 Java 重写(Override)与重载(Overload)
- 20155202张旭 Exp6 信息收集与漏洞扫描
- springboot中的日志配置
- 「小程序JAVA实战」小程序视频处理工具ffmpeg(47)
- bzoj4144 [AMPPZ2014]Petrol