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 入阵曲+将军令+星空的更多相关文章

  1. NOIP模拟测试17&18

    NOIP模拟测试17&18 17-T1 给定一个序列,选取其中一个闭区间,使得其中每个元素可以在重新排列后成为一个等比数列的子序列,问区间最长是? 特判比值为1的情况,预处理比值2~1000的 ...

  2. NOIP模拟测试17「入阵曲&#183;将军令&#183;星空」

    入阵曲 题解 应用了一种美妙移项思想, 我们先考虑在一维上的做法 维护前缀和$(sum[r]-sum[l-1])\%k==0$可以转化为 $sum[r]\% k==sum[l-1]\%k$开个桶维护一 ...

  3. NOIP模拟测试17

    T1:入阵曲 题目大意:给定一个N*M的矩形,问一共有多少个子矩形,使得矩形内所有书的和为k的倍数. 60%:N,M<=80 枚举矩形的左上角和右下角,用二维前缀和求出数字之和. 时间复杂度$O ...

  4. 「题解」NOIP模拟测试题解乱写II(36)

    毕竟考得太频繁了于是不可能每次考试都写题解.(我解释个什么劲啊又没有人看) 甚至有的题目都没有改掉.跑过来写题解一方面是总结,另一方面也是放松了. NOIP模拟测试36 T1字符 这题我完全懵逼了.就 ...

  5. 2019.8.3 [HZOI]NOIP模拟测试12 C. 分组

    2019.8.3 [HZOI]NOIP模拟测试12 C. 分组 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 刚看这题觉得很难,于是数据点分治 k只有1和2两种,分别 ...

  6. 2019.8.3 [HZOI]NOIP模拟测试12 B. 数颜色

    2019.8.3 [HZOI]NOIP模拟测试12 B. 数颜色 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 数据结构学傻的做法: 对每种颜色开动态开点线段树直接维 ...

  7. 2019.8.3 [HZOI]NOIP模拟测试12 A. 斐波那契(fibonacci)

    2019.8.3 [HZOI]NOIP模拟测试12 A. 斐波那契(fibonacci) 全场比赛题解:https://pan.baidu.com/s/1eSAMuXk 找规律 找两个节点的lca,需 ...

  8. 2019.8.1 NOIP模拟测试11 反思总结

    延迟了一天来补一个反思总结 急匆匆赶回来考试,我们这边大家的状态都稍微有一点差,不过最后的成绩总体来看好像还不错XD 其实这次拿分的大都是暴力[?],除了某些专注于某道题的人以及远程爆踩我们的某学车神 ...

  9. NOIP模拟测试1(2017081501)

    好,今天是cgg第一次举行模拟测试,希望各位支持. 时间限制:2小时 题目链接: 题目一:水得都没名字了 题目二:车站 题目三:选数 不要觉得2小时太少,我的题目很良心,都很简单. 答案可以在模拟测试 ...

随机推荐

  1. JVM-基本操作

    1.我们为什么要对jvm做优化?在本地开发环境中我们很少会遇到需要对jvm进行优化的需求,但是到了生产环境,我们可能将有下面的需求: 运行的应用“卡住了”,日志不输出,程序没有反应服务器的CPU负载突 ...

  2. 解决原生javascript 缺少insertAfter的功能,非Jquery方法

    在现有的方法后插入一个新元素,你可能会想:既然有insertBefore方法,是不是也有一个相应的insertAfter()方法.很可惜,DOM没有提供方法.下面编写insertAfter函数,虽然D ...

  3. poj-1104 Robbery

    Robbery Time Limit: 1000MS   Memory Limit: 32768K Total Submissions: 1249   Accepted: 504 Descriptio ...

  4. div+css画一个小猪佩奇

    用DIV+CSS画一个小猪佩奇,挺可爱的,嘻嘻. HTML部分(全是DIV) <!-- 小猪佩奇整体容器 --> <div class="pig_container&quo ...

  5. 使用 jQuery.TypeAhead 让文本框自动完成 (二)(访问远程数据)

    项目地址:https://github.com/twitter/typeahead.js 直接贴代码了: @section headSection { <script type="te ...

  6. 云原生生态周报 Vol. 12 | K8s 1.16 API 重大变更

    本文作者:源三.临石.张磊.莫源 业界要闻 1. K8s 1.16 将废弃一系列旧的 API 版本 影响面涉及 NetworkPolicy.PodSecurityPolicy.DaemonSet, D ...

  7. Node.js能解决什么问题?

    一.使用Node.js能解决什么问题 对于PHP.JAVA.Python等服务端语言中,为每个客户端连接创建一个新的线程,而每个线程需要大约2M的内存,理论上,具有8GB内存的服务器可以同时连接的最大 ...

  8. js 复制 标签中的内容 方法

    <span id='id'>hello world</span><input type='button' onClick='copy("id")' v ...

  9. Winform中对DevExpress的RadopGroup的Description、Value、Tag、Text的理解与使用

    场景 Winform中实现读取xml配置文件并动态配置ZedGraph的RadioGroup的选项: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article ...

  10. 程序员必备技能之Markdown

    Markdown介绍 Markdown是一种纯文本格式的标记语言,比HTML更简单,通过一些简单的语法标记,就可以让文本简洁好看. Markdown已经是程序员一项必备技能了,代码块.流程图.序列图. ...