[NOIP模拟测试12]题解
A.
找规律题。儿子的编号减去 小于它编号的最大的fibonacci数 即可得到它父亲的编号。
然后两个节点都暴力上跳就好了。预处理一下fibonacci数,每次二分查找即可。
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long ll;
int m;
ll fib[];
void pre()
{
fib[]=fib[]=;
for(int i=;i<=;i++)
fib[i]=fib[i-]+fib[i-];
}
int pos(ll x)
{
return lower_bound(fib+,fib+,x)-fib;
}
int main()
{
pre();
scanf("%d",&m);
for(int i=;i<=m;i++)
{
ll a,b;
scanf("%lld%lld",&a,&b);
while(a!=b)
{
if(a>b)a-=fib[pos(a)-];
else b-=fib[pos(b)-];
}
cout<<a<<endl;
}
return ;
}
B.
专治学树锯结垢学傻的我,对每个颜色开一个vector存放出现位置,询问时在相应颜色的vector中二分查找大于等于l与大于r的两个位置,作差即可得到中间有几个位置。
至于修改,如果x与x+1位置的颜色相同就什么都不管,因为换了之后对vector内部没有影响。
如果颜色不同,直接在内部修改坐标信息,然后把颜色和在各自颜色中的相对位置互换。
#include<cstdio>
#include<iostream>
#include<cstring>
#include<vector>
#include<algorithm>
using namespace std;
const int N=;
int n,m,a[N],rk[N];
vector<int> col[N];
int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<='')x=x*+ch-'',ch=getchar();
return x*f;
}
void work()
{
int op=read();
if(op==)
{
int l=read(),r=read(),c=read();
int posl=lower_bound(col[c].begin(),col[c].end(),l)-col[c].begin(),
posr=upper_bound(col[c].begin(),col[c].end(),r)-col[c].begin();
int res=posr-posl;
printf("%d\n",res);
}
else
{
int x=read();
if(a[x]==a[x+])return ;
col[a[x]][rk[x]]=x+;
col[a[x+]][rk[x+]]=x;
swap(rk[x],rk[x+]);
swap(a[x],a[x+]);
}
}
int main()
{
n=read();m=read();
for(int i=;i<=n;i++)
{
a[i]=read();
col[a[i]].push_back(i);
rk[i]=col[a[i]].size()-;
}
while(m--)work();
return ;
}
C.
对于$K=1$的情况,直接贪心从右往左扫,让断点尽量靠前。由于$\max a[i]$为131072,所以两种颜色之和最大为$262144=512^2$。
那么我们只需要记录一下目前在组里出现过的数,判断是否要断就直接从512开始枚举j,看$j*j-a[i]$是否在组里就行了。切断后记得清空之前出现的数,循环到上个断点即可。
$K=2$呢?也是一个道理。像关押罪犯那道题一样利用扩展域并查集维护敌对关系,即一个集合和一个敌对集合。判断到冲突时,看两个数在不在同一集合。在的话被迫断开,不在就维护敌对关系,即将对方的敌对域与自己的己域合并。
但是对于$2*a[i]=x^2$的情况,我们需要进行特判。如果这样的$a[i]$目前只出现了两次,且组里没有它的其它敌对元素,就可以先不设置断点。否则立刻断开清空。
#include<cstdio>
#include<iostream>
#include<cstring>
#include<vector>
using namespace std;
const int N=;
int n,K,a[N],app[N<<];
int st[N];
void work1()
{
for(int i=n;i>=;i--)
{
bool div=;
for(int j=;j>=&&j*j>a[i];j--)
if(app[j*j-a[i]])
{
div=;break;
}
if(div)
{
st[++st[]]=i;
for(int j=i+;j<=(st[]==?n:st[st[]-]);j++)
app[a[j]]=;
//continue;
}
app[a[i]]++;
}
if(!st[])
{
puts("");
printf("\n");
return ;
}
printf("%d\n",st[]+);
while(st[])
printf("%d ",st[st[]]),st[]--;
}
int fa[N],rev[N];
int findf(int x)
{
if(fa[x]==x)return x;
return fa[x]=findf(fa[x]);
}
void work2()
{
int top=;
for(int i=;i<=N-;i++)
fa[i]=i;
st[]=n;
for(int i=n;i>=;i--)
{
for(int j=;j>=&&j*j>a[i];j--)
{
int ene=j*j-a[i];//puts("YOUSA");
if(app[j*j-a[i]]==top)
{
if(a[i]==ene)
{
if(rev[a[i]])
{
for(int k=i;k<=st[top-];k++)
fa[a[k]]=a[k],rev[a[k]]=;
st[top++]=i;
break;
}
else rev[a[i]]=ene;
}
else
{
if(findf(a[i])==findf(ene)||rev[ene]==ene)
{
for(int k=i;k<=st[top-];k++)
fa[a[k]]=a[k],rev[a[k]]=;
st[top++]=i;
break;
}
if(rev[a[i]])
{
int fx=findf(rev[a[i]]),fy=findf(ene);
fa[fx]=fy;
}
else rev[a[i]]=ene;
if(rev[ene])
{
int fx=findf(a[i]),fy=findf(rev[ene]);
fa[fx]=fy;
}
else rev[ene]=a[i];
}
}
}
app[a[i]]=top;
}
printf("%d\n",top);
for(int i=top-;i>=;i--)
printf("%d ",st[i]);
printf("\n");
return ;
}
int main()
{
scanf("%d%d",&n,&K);
for(int i=;i<=n;i++)
scanf("%d",&a[i]);
if(K==)work1();
else work2();
return ;
}
[NOIP模拟测试12]题解的更多相关文章
- 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.3 NOIP模拟测试12 反思总结【P3938 斐波那契,P3939 数颜色,P3940 分组】
[题解在下面] 早上5:50,Gekoo同学来到机房并表态:“打暴力,打暴力就对了,打出来我就赢了.” 我:深以为然. (这是个伏笔) 据说hzoi的人还差两次考试[现在是一次了]就要重新分配机房,不 ...
- [NOIP模拟测试38]题解
来自达哥的问候…… A.金 显然本题的考察点在于高精而不是裴蜀定理 根据裴蜀定理易得答案为Yes当且仅当$gcd(n,m)=1$,那么考虑怎么在高精度下判互质. 如果$n,m$都能被2整除,那么显然不 ...
- 20190803 NOIP模拟测试12「斐波那契(fibonacci)· 数颜色 · 分组 」
164分 rank11/64 这次考的不算太差,但是并没有多大的可能性反超(只比一小部分人高十几分而已),时间分配还是不均,T2两个半小时,T1半个小时,T3-额十几分钟吧 然额付出总是与回报成反比的 ...
- NOIP模拟测试12
T1 斐波那契 一道找规律题,被我做成了贼难的题. 观察图片可知x=f[i-1]+j.(j为x的父亲)且j<=f[i-1],然后就二分找父亲没了. #include<bits/stdc++ ...
- [NOIP模拟测试31]题解
A.math 考场乱搞拿了95,2333. 考虑裴蜀定理:$ax+by=z$存在整数解,当且仅当$gcd(a,b)|z$. 那么如果某个数能够被拼出来,就必须满足所有$a_i$的$gcd$是它的因子. ...
- [NOIP模拟测试30]题解
A.Return 出题人大概是怕自己的中文十级没人知道,所以写了这么一个***题面.可能又觉得这题太水怕全场A掉后自己面子过不去,于是又故意把输出格式说的含糊不清.(鬼知道"那么输出-1&q ...
随机推荐
- 【unp】unix网络编程卷1-->环境搭建(ubuntu14.04)
学习unp网络编程,树上的例子均存在#include "unp.h",故需要对环境进行配置. 1. 到资源页下载unpv13e 2. 解压并将unpv13e 移动到相应的文件夹下 ...
- vue基础八
表单控件绑定 1.基础用法 你可以用 v-model 指令在表单控件元素上创建双向数据绑定.尽管有些神奇,但 v-model 本质上不过是语法糖,它负责监听用户的输入事件以更新数据,并特别处理一些极端 ...
- Python基础教程(012)--排查手误错误
前言 排查由于手误书写错误的方法 内容 手动输入错误的时候,颜色是红色 函数名称写错 1,颜色不一样 2,nameError错误 掌握知识点 学会在写代码的时候排查错误
- BZOJ 3207: 花神的嘲讽计划Ⅰ(莫队+哈希)
传送门 解题思路 刚开始写了个莫队+哈希+\(map\)的\(O(n\sqrt(n)log(n)\)的辣鸡做法,\(T\)飞了.后来看了看别人博客发现其实并不用拿\(map\)当桶存那些哈希值.因为只 ...
- mock 数据 解决方案
前端工程化之--Mock解决方案 https://www.jianshu.com/p/720b12b5d120 一.为什么要使用mock数据: 1.后端接口数据没有的时候,前端根据接口文档,使用 ...
- MCS-51系列单片机和MCS-52系列单片机有何异同
MSC-51:1,片内4K字节程序存储器:2,片内128字节数据存储器:3,片内2个16位硬件定时器/计数器.MSC-52: 1,片内8K字节程序存储器:2,片内256字节数据存储器:3,片内3个16 ...
- Hadoop 家族技能图谱skill-map
----# Hadoop 家族技能图谱- Hadoop- Zookeeper- Avro- Chukwa- Ambari- Whirr- Bigtop- HCatalog- Hue- HBase- P ...
- (4)C++ 复合类型-指针
篇幅长从 https://www.cnblogs.com/buchizaodian/p/11511256.html 提取出来 七.指针和自由存储空间 1.寻址运算符 * #include<io ...
- spring boot starter开发
作为公司的技术保障部,一直承担着技术方向的把控,最近公司准备全面转入spring boot的开发.所以我们部门也一直在调研相关的技术知识点: 使用springboot开发应用已经有一段时间了,我们都沉 ...
- js实现复选框全选/全不选/反选
js实现复选框全选/全不选/反选 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...