8.11 NOIP模拟测试17 入阵曲+将军令+星空
T1 入阵曲
前缀和维护可以得60分 f[x1][y1][x2][y2]=sum[x2][y2]-sum[x1-1][y2]-sum[x2][y1-1]+sum[x1-1][y1-1]; O(n4)
如果同一行的两个前缀和在模k意义下相等,那么他们之间的数的和一定是k的整数倍。把余数拿桶存起来,每次查询之前相同余数的有几个,直接加上。把一行拓展成许多行。
枚举矩阵的左右端点,中间的连续几列压成一列,(然后可以把纸旋转90°)就跟一行的一样了。复杂度O(n3)
需要注意的一点是初始化桶t[0]=1 因为如果这一整块本来就在模k意义下为0,用前缀和求这一段的和需要q[x]-q[0],而q[0]=0,需要把他也放进去。
桶里的东西怎么放进去的怎么拿出来。
ans要开long long
#include<iostream>
#include<cstring>
#include<cstdio>
#define ll long long
using namespace std;
int n,m,k,a[][],sum[][],t[],q[];
ll ans;
int read()
{
int aa=,bb=;char cc=getchar();
while(cc>''||cc<''){if(cc=='-') bb=-;cc=getchar();}
while(cc<=''&&cc>=''){aa=(aa<<)+(aa<<)+(cc^);cc=getchar();}
return aa*bb;
}
int main()
{
n=read();m=read();k=read();
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
a[i][j]=read()%k;
sum[i][j]=(sum[i][j-]+a[i][j])%k;
}
}
for(int i=;i<=m;i++){
for(int j=i;j<=m;j++){
q[]=;t[q[]]=;
for(int l=;l<=n;l++){
q[l]=(q[l-]+sum[l][j]-sum[l][i-]+k)%k;
ans+=t[q[l]];
t[q[l]]++;
}
for(int l=;l<=n;l++) t[q[l]]=;
}
}
printf("%lld\n",ans);
return ;
}
入阵曲
T2 将军令
贪心
找到深度最深的节点,向上找距离他为k的节点,没有就是根,在这驻扎一定优于在这下面的节点,因为越往上他的拓展性越强。
所以每次找到没有被控制的最深的节点,向上找到能控制他且距离最远的祖先,控制他,祖先点亮造成的其他儿子被控制,直接dfs找到并标记,统计答案。
每次贪心的题都不会太难,难的是能想到贪心并且正确实现。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<vector>
#include<algorithm>
using namespace std;
struct node
{
int to,nxt;
}h[];
int n,k,t,tot,ans,nxt[],dep[],f[];
priority_queue< pair<int,int> >q;
bool vis[],flag;
vector<int>ve[];
void add(int x,int y)
{
h[++tot].to=y;
h[tot].nxt=nxt[x];
nxt[x]=tot;
}
void dfs(int x)
{
for(int i=nxt[x];i;i=h[i].nxt){
int y=h[i].to;
if(dep[y]) continue;
dep[y]=dep[x]+;
q.push(make_pair(dep[y],y));
f[y]=x;
dfs(y);
}
}
void dfs1(int x,int d,int fa)
{
if(d>=k) return;
for(int i=nxt[x];i;i=h[i].nxt){
int y=h[i].to;
if(y==fa) continue;
vis[y]=;
dfs1(y,d+,x);
}
}
int main()
{
scanf("%d%d%d",&n,&k,&t);
int u,v;
for(int i=;i<=n-;i++){
scanf("%d%d",&u,&v);
add(u,v);
add(v,u);
}
q.push(make_pair(,));
dep[]=;
dfs();
while(q.size()){
int d=q.top().first,x=q.top().second;
q.pop();
if(!vis[x]){
int fa=x;
for(int i=;i<=k;i++){
if(fa==) break;
fa=f[fa];
}
vis[fa]=;
dfs1(fa,,);
ans++;
}
}
printf("%d\n",ans);
return ;
}
将军令
T3 星空
卡了一下午,有点难过
把亮不亮抽象成01串,没点亮为1,点亮为0(反过来不好做)。区间取反可以用差分单点修改。c[i]=a[i]^a[i+1] c数组为差分数组,下标从0开始。
我们要的最终状态是所有灯都点亮,即全部为0,对应到差分数组上也是全部为0。
因为一共有k个没被点亮,和左边的0会在差分数组里得到一个1,右边同理也会得到一个。所以差分数组里最多有2*k个1。
区间翻转操作在差分数组里就变成了单点修改。翻转[2,4],就是单点修改1和4。
下面的操作均在差分数组上进行
假设我们操作的区间的端点是0和1,把0变成1,1变成0,及相当于1跳了b[i]的距离去找了0,代价为1;如果两个1相遇了,那么就全部翻转,全部变为0(消没了)。所以这就是1跳一跳去找另一个1的问题。。。
考虑在序列上建边,每个点跑b[i]的距离能到达哪,跑最短路。
剩下的就是状压了,把2*k个1状压,看那两个点匹配去消除。
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<vector>
#include<queue>
using namespace std;
struct node
{
int to,nxt;
}h[];
int n,k,m,a[],b[],c[],tot,nxt[],dis[][],cnt,f[(<<)+],pos[(<<)+];
vector<int>ve;
bool vis[];
int lowbit(int x)
{
return x&(-x);
}
void add(int x,int y)
{
h[++tot].to=y;
h[tot].nxt=nxt[x];
nxt[x]=tot;
}
int read()
{
int aa=,bb=;char cc=getchar();
while(cc>''||cc<''){if(cc=='-') bb=-;cc=getchar();}
while(cc<=''&&cc>=''){aa=(aa<<)+(aa<<)+(cc^);cc=getchar();}
return aa*bb;
}
void dj(int p)
{
memset(vis,,sizeof(vis));
queue<int> q;
dis[p][ve[p]]=;
vis[ve[p]]=;
q.push(ve[p]);
while(q.size()){
int x=q.front();q.pop();vis[x]=;
for(int i=nxt[x];i;i=h[i].nxt){
int y=h[i].to;
if(dis[p][y]>=dis[p][x]+){
dis[p][y]=dis[p][x]+;
if(!vis[y]){
vis[y]=;
q.push(y);
}
}
}
}
}
int main()
{
memset(dis,0x3f,sizeof(dis));
memset(f,0x3f,sizeof(f));
n=read();k=read();m=read();
int cc;
for(int i=;i<=k;i++){
cc=read();
a[cc]=;
}
for(int i=;i<=m;i++) b[i]=read();
for(int i=;i<=n;i++){
c[i]=a[i]^a[i+];
if(c[i]) ve.push_back(i);
}
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
if(i-b[j]>=) add(i,i-b[j]);
if(i+b[j]<=n) add(i,i+b[j]);
}
}
cnt=ve.size();
for(int i=;i<=cnt;i++) pos[<<i]=i;
for(int i=;i<cnt;i++) dj(i);
cnt=(<<cnt)-;
f[cnt]=;
for(int i=cnt;i>=;i--){
for(int j=i;j;j-=lowbit(j)){
int x=lowbit(j);
for(int l=j-x;l;l-=lowbit(l)){
int y=lowbit(l);
f[i-x-y]=min(f[i-x-y],f[i]+dis[pos[x]][ve[pos[y]]]);
// cout<<i-x-y<<" "<<pos[x]<<" "<<pos[y]<<" "<<dis[pos[y]]<<" "<<f[i]<<" "<<f[i-x-y]<<endl;
}
}
}
printf("%d\n",f[]);
return ;
}
星空
出题人好像很喜欢五月天的样子。。。
8.11 NOIP模拟测试17 入阵曲+将军令+星空的更多相关文章
- NOIP模拟测试17&18
NOIP模拟测试17&18 17-T1 给定一个序列,选取其中一个闭区间,使得其中每个元素可以在重新排列后成为一个等比数列的子序列,问区间最长是? 特判比值为1的情况,预处理比值2~1000的 ...
- NOIP模拟测试17「入阵曲·将军令·星空」
入阵曲 题解 应用了一种美妙移项思想, 我们先考虑在一维上的做法 维护前缀和$(sum[r]-sum[l-1])\%k==0$可以转化为 $sum[r]\% k==sum[l-1]\%k$开个桶维护一 ...
- NOIP模拟测试17
T1:入阵曲 题目大意:给定一个N*M的矩形,问一共有多少个子矩形,使得矩形内所有书的和为k的倍数. 60%:N,M<=80 枚举矩形的左上角和右下角,用二维前缀和求出数字之和. 时间复杂度$O ...
- 「题解」NOIP模拟测试题解乱写II(36)
毕竟考得太频繁了于是不可能每次考试都写题解.(我解释个什么劲啊又没有人看) 甚至有的题目都没有改掉.跑过来写题解一方面是总结,另一方面也是放松了. NOIP模拟测试36 T1字符 这题我完全懵逼了.就 ...
- 2019.8.3 [HZOI]NOIP模拟测试12 C. 分组
2019.8.3 [HZOI]NOIP模拟测试12 C. 分组 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 刚看这题觉得很难,于是数据点分治 k只有1和2两种,分别 ...
- 2019.8.3 [HZOI]NOIP模拟测试12 B. 数颜色
2019.8.3 [HZOI]NOIP模拟测试12 B. 数颜色 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 数据结构学傻的做法: 对每种颜色开动态开点线段树直接维 ...
- 2019.8.3 [HZOI]NOIP模拟测试12 A. 斐波那契(fibonacci)
2019.8.3 [HZOI]NOIP模拟测试12 A. 斐波那契(fibonacci) 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 找规律 找两个节点的lca,需 ...
- 2019.8.1 NOIP模拟测试11 反思总结
延迟了一天来补一个反思总结 急匆匆赶回来考试,我们这边大家的状态都稍微有一点差,不过最后的成绩总体来看好像还不错XD 其实这次拿分的大都是暴力[?],除了某些专注于某道题的人以及远程爆踩我们的某学车神 ...
- NOIP模拟测试1(2017081501)
好,今天是cgg第一次举行模拟测试,希望各位支持. 时间限制:2小时 题目链接: 题目一:水得都没名字了 题目二:车站 题目三:选数 不要觉得2小时太少,我的题目很良心,都很简单. 答案可以在模拟测试 ...
随机推荐
- idea修改svn地址
1.不能直接修改idea中的svn路径 2.需要先修改小乌龟地址,先找到本地的项目文件右键
- win7 64bit安装redis
win7 64bit安装redis 1 先安装redis客户端 1.下载Redis的压缩包 https://github.com/dmajkic/redis/downloads 我下载的是redis- ...
- OpenGL入门1.3:着色器 GLSL
前言 经过之前一段时间的学习(渲染管线简介)我们已经知道了着色器(Shader)是运行在GPU上的程序,这些小程序为图形渲染管线的某个特定部分而运行,着色器只是一种把输入转化为输出的程序,着色器也是一 ...
- 使用 Floccus 插件和坚果云同步 Chrome 类浏览器书签
使用 Floccus 插件和坚果云同步 Chrome 类浏览器书签 魏刘宏 2019 年 11 月 22 日 如题,本文讨论在使用 Chromium 内核的浏览器上,使用 Floccus 插件,配合 ...
- C# - VS2019 WinFrm应用程序连接Access数据库,并简单实现数据库表的数据查询、显示
序言 众所周知,Oracle数据库和MySQL数据库一般在大型项目中使用,在某些小型项目中Access数据库使用较为方便,今天记录一下VS2019 WinFrm应用程序连接Access数据库,并实现数 ...
- jmeter返回结果出现乱码
这是我的问题: 请求的百度地址,返回的数据是中文乱码 去jmeter安装目录的bin下: 修改配置文件jmeter.properties 右键打开 ,查找:sampleresult.default.e ...
- Java生鲜电商平台-商品无限极目录的设计与架构
Java生鲜电商平台-商品无限极目录的设计与架构 说明:任何一个商品都应该是先属于某一个目录,然后在目录中添加商品,目录理论上最多支持三级,因为级别太多,不容易管理.但是设计中需要设计无限制的级别. ...
- JPA使用Specification构建动态查询
封装Specification查询条件,在Spring Data JPA 2.0以前使用 Specifications 这个辅助类来操作where.not.and和or连接,在2.0版本以后这个类会被 ...
- ios浏览器调试踩坑(1)----mescroll.js和vue-scroller
主要记录在ios浏览器出现触摸无限加载的情况 使用vue-scroller和mescroll.js/mescroll.vue先踩ios浏览器默认滑动会影响mescroll的方法调用. 首先给公共js加 ...
- ios-tableview加载卡顿的解决方案
参考文章:http://www.cocoachina.com/articles/11968 总结: 提前计算并缓存好高度(布局),因为heightForRowAtIndexPath:是调用最频繁的方法 ...