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. .net core session的使用步骤

    步骤 操作 备注 1   Microsoft.AspNetCore.Session Microsoft.AspNetCore.Http.Extensions nuget安装包 2 ConfigureS ...

  2. Tomcat源码分析二:先看看Tomcat的整体架构

    Tomcat源码分析二:先看看Tomcat的整体架构 Tomcat架构图 我们先来看一张比较经典的Tomcat架构图: 从这张图中,我们可以看出Tomcat中含有Server.Service.Conn ...

  3. spring boot通过Jedis来操作redis

    idea中新建spring boot项目,引入jedis依赖 <!-- https://mvnrepository.com/artifact/redis.clients/jedis --> ...

  4. Flex 布局——语法属性详解

    前言 Flexbox 是 flexible box 的简称(注:意思是“灵活的盒子容器”),是 CSS3 引入的新的布局模式.它决定了元素如何在页面上排列,使它们能在不同的屏幕尺寸和设备下可预测地展现 ...

  5. 清理 Sketch缓存 Storyist 3.5.1中文破解版 for Mac

    Sketch这款软件可以用来做原型和UI设计,很多设计师和产品经理都在用,时间长了以后,Sketch会占据不少缓存空间,这时候可以试试 Sketch Cache Cleaner 这款软件清理历史文件和 ...

  6. Win10安装虚拟机 + Ubuntu

    近期需要利用虚拟机,同时在虚拟机中安装Ubuntu系统.整理安装过程,供今后学习参考. 虚拟机安装包:VMware-workstation-full-12.1.0 链接:https://pan.bai ...

  7. Java编程思想——第17章 容器深入研究 读书笔记(三)

    七.队列 排队,先进先出. 除并发应用外Queue只有两个实现:LinkedList,PriorityQueue.他们的差异在于排序而非性能. 一些常用方法: 继承自Collection的方法: ad ...

  8. mvc请求管道(一)

    一.前言 在平常做后台开发的时候,经常会说到请求管道,很多开发者都知道这个,也能说几句,可能没法详细的去介绍,今天就来详细的说一下这个. 二.到达IIS之前 请看下面这个流程图.从用户打开浏览器到请求 ...

  9. opencv::图像矩(Image Moments)

    矩的概念介绍 1.几何矩 2.中心距 3.中心归一化距 4.图像中心Center(x0, y0) 计算矩 moments( InputArray array, // 输入数据 bool binaryI ...

  10. 从零开始搭建Electron+Vue+Webpack项目框架,一套代码,同时构建客户端、web端(一)

    摘要:随着前端技术的飞速发展,越来越多的技术领域开始被前端工程师踏足.从NodeJs问世至今,各种前端工具脚手架.服务端框架层出不穷,“全栈工程师”对于前端开发者来说,再也不只是说说而已.在NodeJ ...