博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[暴力][前缀和] Jzoj P5838 旅游路线
阅读量:5159 次
发布时间:2019-06-13

本文共 1453 字,大约阅读时间需要 4 分钟。

Description

GZOI队员们到X镇游玩。X镇是一个很特别的城镇,它有m+1条东西方向和n+1条南北方向的道路,划分成m*n个区域,这些区域标从北到南、从西到东的坐标标识为从坐标 (1,1) 到坐标(m,n)。 GZOI队员们预先对这m*n个区域打分V(i,j)(分数可正可负)。分数越高表示他们越想到那个地方,越低表示他们越不想去。为了方便游玩,队员们需要选定一个连续的区域集合作为活动范围。例如,如果他们选择了最西北的区域(m1,nl)和最东南(m2,n2)区域(m1<=m2,n1<=n2),那他们的活动范围是 {D(i,j)|m1<=i<=m2,n1<=j<=n2},其游览总分则为这些活动范围的区域总分。 GZOI队员们希望他们活动范围内的区域的分值总和最大。你的任务是编写一个程序,求出他们的活动范围(m1,nl),(m2,n2〉。 
 

Input

输入第一行为整数m(1<=m<=200),n(1<=n<=200),用空格隔开 下面为m行,每行有n列整数,其中第i行第j列的整数,代表V(i,j),每个整数之间用空格隔开,每个整数的范围是 [-200000,200000],输入数据保证这些整数中,至少存在一个正整数。

Output

输出只有一行,为最高的分值。
 

Sample Input

4 51 -2 3 -4 56 7 8 9 10-11 12 13 14 -1516 17 18 19 20

Sample Output

146

 

 

题解

  • 先搞一个前缀和,sum[i][j]表示第i行前j个的和
  • 那么先O(n^2)枚举一个l和一个r
  • 然后再O(n)暴力从上面往下加
  • 如果ans<0把ans=0

代码

1 #include 
2 #include
3 using namespace std; 4 int n,m,a[210][210]; 5 long long sum[210][210],ans,mx; 6 int main() 7 { 8 scanf("%d%d",&n,&m); 9 for (int i=1;i<=n;i++)10 for (int j=1;j<=m;j++)11 {12 scanf("%d",&a[i][j]);13 sum[i][j]=sum[i][j-1]+a[i][j];14 }15 for (int i=1;i<=m;i++)16 for (int j=i;j<=m;j++)17 {18 ans=0;19 for (int k=1;k<=n;k++)20 {21 ans=ans+sum[k][j]-sum[k][i-1];22 mx=max(mx,ans);23 ans=ans<0?0:ans;24 }25 }26 printf("%lld",mx);27 return 0;28 }

 

转载于:https://www.cnblogs.com/Comfortable/p/9511937.html

你可能感兴趣的文章
处理程序“PageHandlerFactory-Integrated”在其模块列表中有一个错误模块“Manag
查看>>
利用SignalR来同步更新Winfrom
查看>>
反射机制
查看>>
CocoaPod
查看>>
BZOJ 1251: 序列终结者 [splay]
查看>>
5G边缘网络虚拟化的利器:vCPE和SD-WAN
查看>>
MATLAB基础入门笔记
查看>>
【UVA】434-Matty&#39;s Blocks
查看>>
Android开发技术周报 Issue#80
查看>>
hadoop2.2.0+hive-0.10.0完全分布式安装方法
查看>>
django知识点总结
查看>>
C++ STL stack、queue和vector的使用
查看>>
使用Reporting Services时遇到的小问题
查看>>
约瑟夫问题
查看>>
Arduino 报错总结
查看>>
树莓派Android Things物联网开发:树莓派GPIO引脚图
查看>>
矩阵快速幂---BestCoder Round#8 1002
查看>>
如何将应用完美迁移至Android P版本
查看>>
【转】清空mysql一个库中的所有表的数据
查看>>
基于wxPython的python代码统计工具
查看>>