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. Windows10 1903错误0xc0000135解决方案

    Windows10 1903错误0xc0000135解决方案 === windows10 1903是2019年Mircosoft推出的最新版windows操作系统,但是有很多机器装上之后会存在不支持. ...

  2. 大神都在用的yum源

    本文原创首发于公众号:编程三分钟 yum 命令的使用 yum命令天天都在用,都快用烂了,但是很多人不知道为什么只要联网,yum命令就能像老奶奶手中的魔法棒一样,随心所欲的下载到想到的包. 比如你想装个 ...

  3. Python 爬虫(四):Selenium 框架

    Selenium 是一个用于测试 Web 应用程序的框架,该框架测试直接在浏览器中运行,就像真实用户操作一样.它支持多种平台:Windows.Linux.Mac,支持多种语言:Python.Perl. ...

  4. Oracle自带工具sql优化集-SQL Tuning Advisor (使用心得体会)

    如何有效的诊断和监控高负载的SQL对于DBA来说并非是件容易的事情,对SQL语句手工调优需要很多的经验和技巧, 结合个人经验常见如下问题:          . 对SQL语句本身进行优化以便获得更优的 ...

  5. mpvue 星星打分组件

    上图: <template> <div class="container"> <div v-for="(star,index) in sta ...

  6. deferred对象和promise对象(一)

    个人认为阮一峰老师讲的关于deferred对象是最容易理解的. deferred对象是jquery的回调函数解决方案.解决了如何处理耗时操作的问题,对那些操作提供了更好的控制,以及统一的编程接口. d ...

  7. # Ubuntu16.04安装nvidia驱动+CUDA+cuDNN

    Ubuntu16.04安装nvidia驱动+CUDA+cuDNN 准备工作 1.查看GPU是否支持CUDA lspci | grep -i nvidia 2.查看Linux版本 uname -m &a ...

  8. Spring源码分析之IOC的三种常见用法及源码实现(一)

    1.ioc核心功能bean的配置与获取api 有以下四种 (来自精通spring4.x的p175) 常用的是前三种 第一种方式 <?xml version="1.0" enc ...

  9. Centos 7.2天兔(Lepus 3.8)数据库监控系统部署

    天兔(Lepus 3.8)数据库监控系统部署 转载自:https://blog.csdn.net/m0_38039437/article/details/79613260 一.安装LAMP基础环境 首 ...

  10. python犯傻之题目解答思路比较与反思

    1.题目: 企业发放的奖金根据利润提成.利润(I)低于或等于10万元时,奖金可提10%: 利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%: 20万 ...