[Codeforces 321D][2018HN省队集训D4T2] Ciel and Flipboard
[Codeforces 321D][2018HN省队集训D4T2] Ciel and Flipboard
题意
给定一个 \(n\times n\) 的矩阵 \(A\), (\(n\) 为奇数) , 每次可以选 \(A\) 的一个 \(\frac {n+1}2 \times \frac {n+1} 2\) 的子矩阵并让这个子矩阵中的所有值取反.
进行若干次操作最大化整个矩阵中的元素值之和. 输出这个最大值.
\(n\le 33\), \(|A_{i,j}|\le 1000\)
题解
毒瘤wls活该被A
hzoi2017_jjm 当场AC, 大强辣!
这题是个结论题.
首先我们看他 \(n\le 33\) 必有高论. 实际上就是个结论优化暴力.
接着我们发现这个 \(\frac{n+1}2\) 非常奥妙重重. 设这个值为 \(m\). 它刚好卡在比一半稍多的位置, 中间的一行一列经常被翻转. 或者说, 只要 \((i,j)\) 被翻转, \((i,m)\) 和 \((m,j)\) 一定也被翻了. 如果 \((i,j)\) 没被翻但是 \((i,m)\) 被翻了, 那么肯定当前操作的子矩阵就被怼到一边去, 导致 \((i,j\pm m)\) 被翻. 不难发现 \((i,j),(i,m),(i,j+m)\) 三个位置在一次操作中如果有一个被翻, 那么必定有且仅有另一个被翻. 也就是说这三个位置的翻转状态的异或和不变且一直是 \(0\).
这个结论显然对于另一维也成立. \((i,j),(m,j),(i+m,j)\) 三个位置的翻转状态的异或和也是 \(0\).
这三个位置的翻转状态只要知道两个显然就能计算出第三个. 而这些关系都和 \((i,m)\) 以及 \((m,j)\) 有关. 我们考虑枚举这些用得很多的位置的翻转状态. (注意到我们对于第 \(m\) 行/列, 只需要枚举一半就可以推出另一半的状态.) 容易发现第 \(m\) 行和第 \(m\) 列的状态确定后, 剩余的位置被分为若干形如 \(\{(i,j),(i+m,j),(i,j+m),(i+m,j+m)\}\) 的组合, 组合之间互相不再有影响. 于是我们可以枚举其中一个位置的状态推出其余位置的状态, 然后两种情况取 \(\max\) 求和即为答案.
虽然我们只需要枚举一半, 但是总枚举量还是有 \(2^n=2^{33}\approx 8\times 10^9\). 再加上还需要 \(O(n^2)\) 验证显然非常不靠谱.
我们又惊奇地发现, 枚举行之后, \(\{(i,j),(i+m,j),(i,j+m),(i+m,j+m)\}\) 只和 \((i,m)\) 有关. 于是我们可以分别枚举 \((i,m)\) 的状态计算一遍和再取 \(\max\) 最后求和.
总时间复杂度 \(O(2^mn^2)\).
参考代码
#include <bits/stdc++.h>
const int MAXN=50;
const int k[2]={1,-1};
int n;
int a[MAXN][MAXN];
int d[MAXN][MAXN];
int main(){
scanf("%d",&n);
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
scanf("%d",a[i]+j);
int m=(n+1)>>1;
int ans=INT_MIN;
for(int s=0;s<(1<<m);s++){
int sum=0;
for(int i=0;i<m;i++)
d[m-1][i]=((s>>i)&1)?1:-1;
for(int i=m;i<n;i++)
d[m-1][i]=d[m-1][i-m]*d[m-1][m-1];
for(int i=0;i<n;i++)
sum+=d[m-1][i]*a[m-1][i];
for(int i=0;i<m-1;i++){
int cur=INT_MIN;
for(int r=0;r<2;r++){
d[i][m-1]=k[r];
d[i+m][m-1]=d[i][m-1]*d[m-1][m-1];
int now=d[i][m-1]*a[i][m-1]+d[i+m][m-1]*a[i+m][m-1];
for(int j=0;j<m-1;j++){
int tmp=INT_MIN;
for(int r=0;r<2;r++){
d[i][j]=k[r];
d[i+m][j]=d[i][j]*d[m-1][j];
d[i][j+m]=d[i][j]*d[i][m-1];
d[i+m][j+m]=d[i+m][j]*d[i+m][m-1];
tmp=std::max(tmp,d[i][j]*a[i][j]+d[i+m][j]*a[i+m][j]+d[i][j+m]*a[i][j+m]+d[i+m][j+m]*a[i+m][j+m]);
}
now+=tmp;
}
cur=std::max(cur,now);
}
sum+=cur;
}
ans=std::max(ans,sum);
}
printf("%d\n",ans);
return 0;
}

[Codeforces 321D][2018HN省队集训D4T2] Ciel and Flipboard的更多相关文章
- [2018HN省队集训D9T1] circle
[2018HN省队集训D9T1] circle 题意 给定一个 \(n\) 个点的竞赛图并在其中钦定了 \(k\) 个点, 数据保证删去钦定的 \(k\) 个点后这个图没有环. 问在不删去钦定的这 \ ...
- [2018HN省队集训D8T1] 杀毒软件
[2018HN省队集训D8T1] 杀毒软件 题意 给定一个 \(m\) 个01串的字典以及一个长度为 \(n\) 的 01? 序列. 对这个序列进行 \(q\) 次操作, 修改某个位置的字符情况以及查 ...
- [2018HN省队集训D8T3] 水果拼盘
[2018HN省队集训D8T3] 水果拼盘 题意 给定 \(n\) 个集合, 每个集合包含 \([1,m]\) 中的一些整数, 在这些集合中随机选取 \(k\) 个集合, 求这 \(k\) 个集合的并 ...
- [2018HN省队集训D6T2] girls
[2018HN省队集训D6T2] girls 题意 给定一张 \(n\) 个点 \(m\) 条边的无向图, 求选三个不同结点并使它们两两不邻接的所有方案的权值和 \(\bmod 2^{64}\) 的值 ...
- [Luogu P4143] 采集矿石 [2018HN省队集训D5T3] 望乡台platform
[Luogu P4143] 采集矿石 [2018HN省队集训D5T3] 望乡台platform 题意 给定一个小写字母构成的字符串, 每个字符有一个非负权值. 输出所有满足权值和等于这个子串在所有本质 ...
- [2018HN省队集训D5T2] party
[2018HN省队集训D5T2] party 题意 给定一棵 \(n\) 个点以 \(1\) 为根的有根树, 每个点有一个 \([1,m]\) 的权值. 有 \(q\) 个查询, 每次给定一个大小为 ...
- [2018HN省队集训D5T1] 沼泽地marshland
[2018HN省队集训D5T1] 沼泽地marshland 题意 给定一张 \(n\times n\) 的棋盘, 对于位置 \((x,y)\), 若 \(x+y\) 为奇数则可能有一个正权值. 你可以 ...
- [2018HN省队集训D1T3] Or
[2018HN省队集训D1T3] Or 题意 给定 \(n\) 和 \(k\), 求长度为 \(n\) 的满足下列条件的数列的数量模 \(998244353\) 的值: 所有值在 \([1,2^k)\ ...
- [2018HN省队集训D1T1] Tree
[2018HN省队集训D1T1] Tree 题意 给定一棵带点权树, 要求支持下面三种操作: 1 root 将 root 设为根. 2 u v d 将以 \(\operatorname{LCA} (u ...
随机推荐
- RabbitMQ上手记录–part 5-节点集群高可用(多服务器)
上一part<RabbitMQ上手记录–part 4-节点集群(单机多节点)>中介绍了RabbitMQ集群的一些概念以及实现了在单机上运行多个节点,并且将多个节点组成一个集群. 通常情况下 ...
- 把AspDotNetCoreMvc程序运行在Docker上-part5:使用docker-compose
在上一part<把AspDotNetCoreMvc程序运行在Docker上-part4:实现负载均衡>中,我们通过几个比较复杂的步骤在docker平台上实现了对网站程序的负载均衡,配置步骤 ...
- [转]微信小程序之加载更多(分页加载)实例 —— 微信小程序实战系列(2)
本文转自;http://blog.csdn.net/michael_ouyang/article/details/56846185 loadmore 加载更多(分页加载) 当用户打开一个页面时,假设后 ...
- C#/Net代码精简优化技巧
(一) 在我们写代码的时候可以使用一些小的技巧来使代码变得更加简洁,易于维护和高效.下面介绍几种在C#/Net中非常有用的一些编程技巧. 1 空操作符(??) 在程序中经常会遇到对字符串或是对象判断n ...
- POJ3279(KB1-D 熄灯问题)
Fliptile Description Farmer John knows that an intellectually satisfied cow is a happy cow who will ...
- Review——JS的异步与同步
一.概念 同步(synchronous):指在js的主线程上,所有任务被依次执行: 异步(asynchronous):指任务不进入主线程,进入任务队列(task):当“任务队列”通知主线程,异步任务才 ...
- 【朴灵评注】JavaScript 运行机制详解:再谈Event Loop
PS: 我先旁观下大师们的讨论,得多看书了~ 别人说的:“看了一下不觉得评注对到哪里去,只有吹毛求疵之感. 比如同步异步介绍,本来就无大错:比如node图里面的OS operation,推敲一下就 ...
- sqlserver年月日转汉字大写
也是今天sql群里有人问,看起来这个问题挺简单,但是我不知道具体该怎么实现.百度了一把,找到一个高手贡献的答案,记一下. 参考链接 sql中转换中文日期 ------ 配合相关函数 ------ cr ...
- 知识蒸馏(Distillation)
蒸馏神经网络取名为蒸馏(Distill),其实是一个非常形象的过程. 我们把数据结构信息和数据本身当作一个混合物,分布信息通过概率分布被分离出来.首先,T值很大,相当于用很高的温度将关键的分布信息从原 ...
- flutter圆角效果的实现
new Material( borderRadius: BorderRadius.circular(20.0), shadowColor: Colors.blue.shade200, elevatio ...