codeforces Gargari and Bishops(很好的暴力)

 1 /*
 2     题意:给你一个n*n的格子,每一个格子都有一个数值!将两只bishops放在某一个格子上,
 3     每一个bishop可以攻击对角线上的格子(主对角线和者斜对角线),然后会获得格子上的
 4     数值(只能获取一次)。要求输出两个bishops获取的最大值以及它们所在的位置!
 5     
 6     
 7     思路:直接暴力!....不错的暴力题目! 
 8     首先我们都知道每一条主对角线上的横纵坐标的和相同,每一条副对角线上的横纵坐标的差相同!
 9     那么我们在输入的时候就可以将所有对角线上的数值之和求出来了! 
10     
11     最后我们发现如果要获得最大值,那么还有一条就是两个bishops所在的对角线不能相交在
12     同一个格子上!只要满足两个bishops的哼纵坐标之和互为奇偶就可以了! 
13     
14     在所有格子中找到横纵坐标之和为奇数并且获得对角线上数值最大的格子和横纵坐标之
15     和为偶数并且获得对角线上数值最大的格子! 
16     二者最大获得值相加就是最终的答案了! 
17 */
18 #include<iostream>
19 #include<cstring>
20 #include<cstdio>
21 #include<algorithm>
22 #define N 2005
23 using namespace std;
24 typedef long long LL; 
25 int num[N][N];
26 LL sumN[N*2], sumM[N*2];
27 
28 int n;
29 
30 int main(){
31     while(scanf("%d", &n)!=EOF){
32         memset(sumN, 0, sizeof(sumN));
33         memset(sumM, 0, sizeof(sumM));
34         for(int i=1; i<=n; ++i)
35               for(int j=1; j<=n; ++j){ 
36                 scanf("%d", &num[i][j]);
37                 sumN[i+j]+=num[i][j];//横纵坐标之和为i+j的对角线的数值和 
38                 sumM[i-j+n]+=num[i][j];//横纵坐标之差为i-j的对角线的数值和 
39             }
40     
41         LL maxOdd=-1, maxEvent=-1, s;
42         int x1, x2, y1, y2;
43         for(int i=1; i<=n; ++i)
44              for(int j=1; j<=n; ++j){
45                  if((i+j)&1){ 
46                      if(maxOdd<(s=sumN[i+j]+sumM[i-j+n]-num[i][j])){
47                          maxOdd=s;//横纵坐标之和为奇数并且获得对角线上数值最大的格子
48                          x1=i;
49                          y1=j;
50                      }
51                 }
52                 else{
53                      if(maxEvent<(s=sumN[i+j]+sumM[i-j+n]-num[i][j])){
54                          maxEvent=s;//横纵坐标之和为偶数并且获得对角线上数值最大的格子
55                          x2=i;
56                          y2=j;
57                      }
58                 }
59             }
60 
61         printf("%lld\n",maxOdd+maxEvent);     
62         printf("%d %d %d %d\n", x1, y1, x2, y2);
63     }
64      return 0;
65 } 

 

转载于:https://www.cnblogs.com/hujunzheng/p/3946876.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值