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);
}
}
}

溜了。

最新文章

  1. Android请求网络共通类——Hi_博客 Android App 开发笔记
  2. Spring+EhCache缓存实例
  3. document.execCommand 常用的方法
  4. s3c2440 移值u-boot-2016.03 第1篇 新建单板
  5. 利用js排序html表格
  6. MSSQLServer基础06(变量,case,选择语句)
  7. 从NIB中加载VIEW
  8. IE8下的项目在IE11下某些功能无法实现的问题
  9. QT中的qmake详解
  10. wrapper x64 版本发布到centos
  11. Sublime Text3时间戳查看转换插件的开发
  12. 微信小程序自定义导航栏
  13. 编写函数求整形数组a中存储的m个不重复的整数的第k大的整数(其中m&gt;=1,1&lt;=k&lt;=m)很简单的一个思路是酱紫的:管他辣么多干啥,上来一把排序然后直接得答案
  14. sublime text 3中安装ctags支持函数跳转,安装convertToUtf8支持中文步骤[工具篇]
  15. armv8 memory system
  16. Java - 21 Java 重写(Override)与重载(Overload)
  17. 20155202张旭 Exp6 信息收集与漏洞扫描
  18. springboot中的日志配置
  19. 「小程序JAVA实战」小程序视频处理工具ffmpeg(47)
  20. bzoj4144 [AMPPZ2014]Petrol

热门文章

  1. 【bzoj2659】[Beijing wc2012]算不出的算式 数论
  2. 【题解】SCOI2010幸运数字
  3. 【算法】最小乘积生成树 &amp; 最小乘积匹配 (HNOI2014画框)
  4. [bzoj4071] [Apio2015]巴邻旁之桥
  5. sqlserver数据库迁移
  6. Seajs的用法
  7. taotao购物车2 解决购物车本地cookie和服务器redis不同步的问题
  8. mysql的中文乱码问题
  9. Phantomjs设置浏览器useragent的方式
  10. es6+最佳入门实践(13)