T1 斐波那契

一道找规律题,被我做成了贼难的题。

观察图片可知x=f[i-1]+j。(j为x的父亲)且j<=f[i-1],然后就二分找父亲没了。

 #include<bits/stdc++.h>
#define ll long long
using namespace std;
const int mod=;
ll f[];
struct Hush{
int head[],nxt[],cnt;
ll to[];
void insert(ll x)
{
int k=x%mod;
to[++cnt]=x;
nxt[cnt]=head[k];
head[k]=cnt;
return ;
}
bool find(ll x)
{
int k=x%mod;
for(int i=head[k];i;i=nxt[i])if(to[i]==x)return ;
return ;
}
void clear()
{
memset(head,,sizeof(head));
cnt=;
}
}H;
ll Getlca(ll a,ll b)
{
if(a>b)swap(a,b);
H.clear();
H.insert(a);
while(a!=)
{
ll fa=lower_bound(f+,f+,a)-f;
fa=a-f[fa-];
H.insert(fa);
a=fa;
}
if(H.find(b))return b;
while(b!=)
{
ll fb=lower_bound(f+,f+,b)-f;
fb=b-f[fb-];
if(H.find(fb))return fb;
b=fb;
}
}
int main()
{
f[]=;f[]=;
for(int i=;i<=;i++)f[i]=f[i-]+f[i-];
int m;
scanf("%d",&m);
for(int i=;i<=m;i++)
{
ll a,b;
scanf("%lld%lld",&a,&b);
printf("%lld\n",Getlca(a,b));
}
return ;
}

T2 水题不说了

T3 分组

一道好题。

k=1:

以前做过一道菜肴制作,然后就可以知道:区间越往后放,就越靠前。然后就维护最长的区间即可

k=2:

用扩展域并查集,直接维护,特判很恶心。

 #include<bits/stdc++.h>
#define MAXN 333333
using namespace std;
int nxt[MAXN],a[MAXN],pf[MAXN],dr[MAXN],f[MAXN];
bool vst[MAXN];
vector<int>ans,cl;
inline int find(int x)
{
return f[x]==x?x:f[x]=find(f[x]);
}
inline void merge(int x,int y)
{
int fa=find(x),fb=find(y);
f[fa]=fb;
return ;
}
void bcj_clear(int l,int r)
{
for(int i=l;i<=r;i++)f[a[i]]=a[i],vst[a[i]]=,dr[a[i]]=;
cl.clear();
return ;
}
int main()
{
int n,k,maxa=;
scanf("%d%d",&n,&k);
for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
maxa=max(maxa,a[i]);
}
int ed=n;
for(int i=;i<=;i++)pf[i]=i*i;
if(k==)
{
for(int i=n;i>=;i--)
{
bool ok=;
for(int j=sqrt(maxa*);j>=&&pf[j]>=a[i];j--)
if(vst[pf[j]-a[i]]){ok=;break;}
if(!ok){
ed=i;
for(int k=;k<cl.size();k++)
vst[cl[k]]=;
cl.clear();
ans.push_back(i);
}
vst[a[i]]=;
cl.push_back(a[i]);
}
if(!ans.size())printf("1\n");
cout<<ans.size()+<<endl;
for(int i=ans.size()-;i>=;i--)
printf("%d ",ans[i]);
return ;
}
else
{
int last=n;
for(int i=;i<=maxa*;i++)f[i]=i;
for(int i=n;i>=;i--)
{
bool ok=;
for(int j=sqrt(maxa*);j>=&&pf[j]>=a[i];j--)
{
if(vst[pf[j]-a[i]]&&!vst[a[i]])
{
// cout<<i<<"---"<<endl;
int now=pf[j]-a[i];
if(find(a[i])==find(now)){ok=;break;}
if(!dr[now])dr[now]=a[i];
else if(dr[now]!=now)merge(dr[now],a[i]);
else {ok=;break;}
if(!dr[a[i]])dr[a[i]]=now;
else if(dr[a[i]]!=a[i])merge(dr[a[i]],now);
else {ok=;break;}
}
else if(vst[pf[j]-a[i]]&&a[i]==pf[j]-a[i])
{
// cout<<i<<' '<<dr[a[i]]<<endl;
if(dr[a[i]]){ok=;break;}
else dr[a[i]]=a[i];
//cout<<i<<' '<<a[i]<<")S"<<endl;
}
}
if(!ok){
ed=i;
bcj_clear(i,last);
last=i;
ans.push_back(i);
}
vst[a[i]]=;
cl.push_back(a[i]);
}
if(!ans.size()){printf("1\n");return ;}
cout<<ans.size()+<<endl;
for(int i=ans.size()-;i>=;i--)
printf("%d ",ans[i]);
return ;
}
}

主要反思一下:

考试策略不好,时间分配不合理,难度评估sb 认为T1最难,T3最水?????????

端正心态,不要去刚题,但也不要轻易放弃(暴力还是要打的)

NOIP模拟测试12的更多相关文章

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

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

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

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

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

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

  4. 2019.8.3 NOIP模拟测试12 反思总结【P3938 斐波那契,P3939 数颜色,P3940 分组】

    [题解在下面] 早上5:50,Gekoo同学来到机房并表态:“打暴力,打暴力就对了,打出来我就赢了.” 我:深以为然. (这是个伏笔) 据说hzoi的人还差两次考试[现在是一次了]就要重新分配机房,不 ...

  5. 20190803 NOIP模拟测试12「斐波那契(fibonacci)· 数颜色 · 分组 」

    164分 rank11/64 这次考的不算太差,但是并没有多大的可能性反超(只比一小部分人高十几分而已),时间分配还是不均,T2两个半小时,T1半个小时,T3-额十几分钟吧 然额付出总是与回报成反比的 ...

  6. [NOIP模拟测试12]题解

    A. 找规律题.儿子的编号减去 小于它编号的最大的fibonacci数 即可得到它父亲的编号. 然后两个节点都暴力上跳就好了.预处理一下fibonacci数,每次二分查找即可. #include< ...

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

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

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

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

  9. NOIP模拟测试17&18

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

随机推荐

  1. Network in Network(2013),1x1卷积与Global Average Pooling

    目录 写在前面 mlpconv layer实现 Global Average Pooling 网络结构 参考 博客:blog.shinelee.me | 博客园 | CSDN 写在前面 <Net ...

  2. CONVERT用法指南,时间字段截取方法

    语法: CONVERT(VARCHAR(7),<字段名称>,121) 时间转字符:select CONVERT(VARCHAR(7),dyxq,121),* from TBYPKC03-- ...

  3. POJ1017&&UVA311 Packets(中文题面版)

    感谢有道翻译--- Description A工厂生产的产品是用相同高度h的方形包装,尺寸为1* 1,2 * 2,3 * 3,4 * 4,5 * 5,6 6.这些产品总是以与产品高度h相同,尺寸为66 ...

  4. 深度长文回顾web基础组件

    什么是Serlvet ? 全称 server applet 运行在服务端的小程序: 首先来说,这个servlet是java语言编写的出来的应用程序,换句话说servlet拥有java语言全部的优点,比 ...

  5. JS循环+循环嵌套+经典例题+图形题

    首先,了解一下循环嵌套的特点:外层循环转一次,内层循环转一圈. 在上一篇随笔中详细介绍了JS中的分支结构和循环结构,我们来简单的回顾一下For循环结构: 1.for循环有三个表达式,分别为: ①定义循 ...

  6. [JZOJ5456]【NOIP2017提高A组冲刺11.6】奇怪的队列

    Description nodgd的粉丝太多了,每天都会有很多人排队要签名.今天有

  7. 真——Springcloud支持Https

    很久不写了,因为一直没有一个项目的需求推动,担心写的东西可能不是太实际.其间学习的事倒是做了不少,设计模式.领域开发.Antlr.kubernetes等等,其实大部分都记在纸质笔记上了.. 基于对新技 ...

  8. .Net Core 3.0 IdentityServer4 快速入门02

    .Net Core 3.0 IdentityServer4 快速入门 —— resource owner password credentials(密码模式) 一.前言 OAuth2.0默认有四种授权 ...

  9. Codeforces--Books Exchange (hard version)

    题目链接http://codeforces.com/contest/1249/problem/B2 .并查集思想,将数分成多个集合,每个集合的大小就是一轮的所需天数. Map[i]存储数据. flag ...

  10. 06_基本框架_VMCS_GuestArea

    1 Guest-State Area 1.1 References 注释: 其实 内容很多 一般是不背 的:需要的时候来查就行:但是要大致知道是做啥的. 代码 > 设置 Guest Area / ...