前言

我就想说一句,T3 给了一个什么牛马大样例!!!!!!!!,气\(^{TM}\)死我!!!!!!!

我的 \(\mathcal{O}(n)\) 算法始终过不掉大样例我 TM ,要不然我就直接上矩阵乘优化了。。

最后没法了把我的所谓的不正确的正解交上去,考完发现有 56pts ,我以为是数据水,果断去看正解。。

苦思冥想了好久直到战神大样例没过切掉了此题,我才开始矩阵乘优化,然后就过了(然而和题解柿子完全不一样。。)

牛马大样例!!!!

T1 自然数

解题思路

考场上一眼 CDQ 分治,最后一看果然不是。。(逃

可惜的是我打的小暴力还被卡常卡掉了 34pts 。。。

对于每一个左端点线段树维护出每一个右端点的和,因此我们先求出左端点为 1 的所有答案作为初始值加入到线段树中。

然后向右移动左端点,每次相当于删去一个值 \(x\) 那么在当前扫到的左端点到 \(x\) 的上一次出现位置的所有大于 \(x\) 的答案都会变为 \(x\) 。

由于答案的值是单调不降的,因此我们可以二分答案在线段树上面查值,也可以线段树上二分,复杂度带一个或者两个 log

code

#include <bits/stdc++.h>
#define int long long
#define ull unsigned long long
#define f() cout<<"Failed"<<endl
#define ls x<<1
#define rs x<<1|1
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
return x*f;
}
const int N=2e5+10;
int n,ans,nxt[N],s[N],cnt[N],num[N];
unordered_map<int,int> mp;
struct Segment_Tree
{
struct Node{int mn,dat,laz;}tre[N<<2];
void push_up(int x)
{
tre[x].mn=min(tre[ls].mn,tre[rs].mn);
tre[x].dat=tre[ls].dat+tre[rs].dat;
}
void push_down(int x,int l,int r)
{
if(tre[x].laz==-1) return ;
int mid=(l+r)>>1;
tre[ls].laz=tre[x].laz; tre[rs].laz=tre[x].laz;
tre[ls].dat=(mid-l+1)*tre[x].laz; tre[rs].dat=(r-mid)*tre[x].laz;
tre[ls].mn=tre[rs].mn=tre[x].laz;
tre[x].laz=-1;
}
void build(int x,int l,int r)
{
tre[x].laz=-1;
if(l==r) return tre[x].mn=tre[x].dat=num[l],void();
int mid=(l+r)>>1;
build(ls,l,mid); build(rs,mid+1,r);
push_up(x);
}
void insert(int x,int l,int r,int L,int R,int val)
{
if(L<=l&&r<=R) return tre[x].dat=val*(r-l+1),tre[x].laz=tre[x].mn=val,void();
int mid=(l+r)>>1; push_down(x,l,r);
if(L<=mid) insert(ls,l,mid,L,R,val);
if(R>mid) insert(rs,mid+1,r,L,R,val);
push_up(x);
}
int query(int x,int l,int r,int L,int R)
{
if(L<=l&&r<=R) return tre[x].dat;
int mid=(l+r)>>1,sum=0; push_down(x,l,r);
if(L<=mid) sum+=query(ls,l,mid,L,R);
if(R>mid) sum+=query(rs,mid+1,r,L,R);
return sum;
}
int query(int x,int l,int r,int pos)
{
if(l==r) return tre[x].mn;
int mid=(l+r)>>1; push_down(x,l,r);
if(pos<=mid) return query(ls,l,mid,pos);
return query(rs,mid+1,r,pos);
}
}T;
signed main()
{
freopen("mex.in","r",stdin); freopen("mex.out","w",stdout);
n=read(); for(int i=1;i<=n;i++) s[i]=read();
for(int i=1,pos=0;i<=n;i++)
{
if(s[i]<=n) cnt[s[i]]++;
while(cnt[pos]) pos++;
num[i]=pos;
}
T.build(1,1,n);
for(int i=n;i;i--)
{
nxt[i]=n+1;
if(mp.find(s[i])==mp.end()){mp.insert(make_pair(s[i],i));continue;}
nxt[i]=mp.find(s[i])->second; mp[s[i]]=i;
}
for(int i=1;i<=n;i++)
{
ans+=T.query(1,1,n,i,n);
int l=i,r=nxt[i]-1,temp=-1;
while(l<=r)
{
int mid=(l+r)>>1;
if(T.query(1,1,n,mid)>s[i]) temp=mid,r=mid-1;
else l=mid+1;
}
if(~temp) T.insert(1,1,n,temp,nxt[i]-1,s[i]);
}
printf("%lld",ans);
return 0;
}

T2 钱仓

解题思路

显然的一个结论一定存在一个点,使得按照顺时针顺序原来在它之前的点上的钱一定不会运到在它之后的点上。

于是我们就可以得到枚举断点求答案的 \(\mathcal{O}(n^2)\) 做法。

然后发现所有合法的序列其实答案都是相同的,我是我们可以枚举 \([1,2n]\) 查看是否有长度为 \(n\) 的一段。

满足一段内距离左端点的前缀和与长度的差值始终大于等于 0。

直接从该断点计算即可。

code

#include <bits/stdc++.h>
#define int long long
#define ull unsigned long long
#define f() cout<<"Failed"<<endl
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}
return x*f;
}
const int N=2e5+10,INF=1e18;
int n,ans=INF,beg,s[N],p[N];
void solve(int fro)
{
for(int i=fro,temp=0;i<=fro+n-1;i++)
{
temp+=s[i]-1; p[i-fro+1]=s[i];
if(temp<0) return ;
}
int sum=0,pos=1; p[pos]--;
for(int i=2;i<=n;i++)
{
while(!p[pos]) pos++;
p[pos]--; sum+=(i-pos)*(i-pos);
}
ans=min(ans,sum);
}
signed main()
{
freopen("barn.in","r",stdin); freopen("barn.out","w",stdout);
n=read(); for(int i=1;i<=n;i++) s[i+n]=s[i]=read();
for(int i=1,sum=0;i<=2*n;i++)
{
sum+=s[i];
if(sum-i+beg<0) beg=i,sum=0;
if(i-beg==n) break;
}
solve(beg+1); printf("%lld",ans);
return 0;
}

T3 游戏

解题思路

如果没有那个大样例的话这绝对称得上是个期望好题。

易得,在只剩下一个棋子的时候都希望自己可以拿走,那么在剩下两个石子的时候一定都希望自己下一局先手,从而不希望本局可以取到石子。

以此类推,可以发现剩下奇数个石子的时候两人都想到得到,偶数时则相反。

假设这一局 \(A\) 先手的概率是 \(lasa\) , \(B\) 先手的概率是 \(lasb\) ,下一局的概率是 \(A,B\) 。

NOIP模拟74的更多相关文章

  1. Noip模拟74 2021.10.11

    T1 自然数 考场上当我发现我的做法可能要打线段树的时候,以为自己百分之百是考虑麻烦了 但还是打了,还过掉了所有的样例,于是十分自信的就交了 正解还真是线段树,真就第一题数据结构 但是包括自己造的小样 ...

  2. 2021.10.11考试总结[NOIP模拟74]

    T1 自然数 发现\(mex\)是单调不降的,很自然地想到用线段树维护区间端点的贡献. 枚举左端点,用线段树维护每个右端点形成区间的\(mex\)值.每次左端点右移相当于删去一个数. 记\(a_i\) ...

  3. NOIP模拟17.9.22

    NOIP模拟17.9.22 前进![问题描述]数轴的原点上有一只青蛙.青蛙要跳到数轴上≥

  4. NOIP 模拟4 T2

    本题属于二和一问题 子问题相互对称 考虑对于问题一:知a求b 那么根据b数组定义式 显然能发现问题在于如何求dis(最短路) 有很多算法可供选择 dijsktra,floyed,bfs/dfs,spf ...

  5. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  6. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  7. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  8. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  9. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

随机推荐

  1. centos7 添加磁盘到/(根目录下),扩展VG卷和lv

    转载自:http://blog.itpub.net/25469263/viewspace-2662215/ centos7中使用vg方式扩充root分区 1.创建pv fdisk /dev/sdb 输 ...

  2. 关于int和Integer缓存(一):以及设计构想(享元模式)

    关于Integer的值缓存:在介绍Integer的值缓存之前,我们需要了解的是,java中的包装类型,我们都知道java中有包装类型int                     Integer    ...

  3. Ubuntu 16.04LTS安装flashplayer

    转载自http://www.linuxdiyf.com/linux/20084.html 在安装Ubuntu 16.04LTS后,播放有视频的网页时,总提示你要安装缺失的插件,在 ubuntu 系统下 ...

  4. Ubuntu16.04 Linux 下安装、配置SSH

    本人在Win7+VMware下利用两个ubuntu虚拟机安装.配置.测试了SSH. 在Server端安装openssh-server. sudo apt-get install ssh # 安装ssh ...

  5. java对象的引用级别

    解释 在java中也有引用的概念,其实就可以认为是变量.标题中的引用级别是指变量与对象之前的引用级别.java中分为4种,按引用强弱关系排序分别是:强引用.软引用.弱引用.虚引用. 强引用(Stron ...

  6. IMO 1977 第 2 题探析

    原题:在一个有限的实数数列中,任意 7 个连续项之和为负数,且任意 11 个连续项之和为正数.求这个数列最多有多少项. 解法一:记这个数列为 a1, a2, ..., ak,问题等价于求 k 的最大值 ...

  7. Kickstart无人值守原理及简介

    原文转自:https://www.cnblogs.com/itzgr/p/10029461.html作者:木二 目录 一 简介及原理 二 搭建无人值守步骤 三 PXE介绍 四 Kickstart简介 ...

  8. mybaits源码分析--自定义插件(七)

    一.MyBatis插件 插件是一种常见的扩展方式,大多数开源框架也都支持用户通过添加自定义插件的方式来扩展或者改变原有的功能,MyBatis中也提供的有插件,虽然叫插件,但是实际上是通过拦截器(Int ...

  9. Mac shell 调节音量

    $ osascript -e 'get volume settings' $ osascript -e 'output volume of (get volume settings)' $ osasc ...

  10. 命令行解析函数:getopt_long、getopt

    一.前言 在学习一些项目代码时,尤其涉及到命令行传参的代码,经常遇到getopt相关的函数,对这一类函数可以说是既陌生又熟悉.陌生是因为不知道它是干啥的,熟悉呢,是因为经常遇到.于是乎在追踪了多天ip ...