20210716考试-NOIP16
考场时Prim的 $i$ 写成 $k$ 100->0 rank1->rank23
T1 Star Way To Heaven
考场正解:假设你要二分答案,则几个圆组成几道“屏障”把画面切成几部分,走每一个屏障的最长边的中点,这样是最优的。
但是屏障间的点可能对答案有影响,所以要把它们合成为一道屏障。
首先取上或下边界,如集合,之后每次取离集合最近的点加入集合,这样就可以找到“屏障”合成后的样子,因为:
对于这样子的三个点,$d(1,2),d(2,3)<=d(1,3)$,所以对于题目而言,只使用 $d(1,2),d(2,3)$ 的距离就可以成功限制好对答案的影响。
在求出的点集中的边取最大值的一半即为答案。
#include<bits/stdc++.h>
using namespace std;
const int N=1100000,K=6100;
const long double INF=0x7fffffff;
inline int read()
{
int s=0,w=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')w=-1;ch=getchar();}
while(isdigit(ch)){s=s*10+ch-'0';ch=getchar();}
return s*w;
}
int n,m,k;
bool vis[K];
long double x[K],y[K],ans,dis[K];
long double X(int q)
{
return x[q];
}
long double Y(int q)
{
return y[q];
}
long double D(int a,int b)
{
return sqrt((X(a)-X(b))*(X(a)-X(b))+(Y(a)-Y(b))*(Y(a)-Y(b)));
}
int main()
{
n=read();m=read();k=read();
for(int i=1;i<=k;i++)
{
scanf("%Lf%Lf",&x[i],&y[i]);
}
for(int i=1;i<=k;i++)
{
dis[i]=1.0*y[i];
}
dis[k+1]=m;
for(int i=1;i<=k+1;i++)
{
long double minn=INF;
int x=-1;
for(int j=1;j<=k+1;j++)
{
if(vis[j])
continue;
if(dis[j]<minn)
{
minn=dis[j];
x=j;
}
}
vis[x]=1;
ans=max(dis[x],ans);
if(x==k+1)
{
printf("%.8Lf\n",ans*0.5);
return 0;
}
for(int j=1;j<=k;j++)
{
if(!vis[j])
{
dis[j]=min(dis[j],max(dis[x],D(x,j)));
}
}
dis[k+1]=min(dis[k+1],m-y[x]);
}
// printf("%.8Lf\n",ans/2.0);
return 0;
}
/*
10 5 2
1 1
2 3
*/
T2 God Knows
玄学DP,考场想50mins没想出 $n^2$ DP,写了一个只能过样例的假DP竟然有10分...
我对这个DP理解并不深,这篇博客更好。
\begin{align}
f[i]=\min f[j]+c[i] (j < i\And p[j] < p[i] \And \forall j< k < i , p[k] < p[j] || p[k] > p[i] )
\end{align}
f[i]表示前i个点已经被解决。
对这个式子的解释是:f[i]如果要从f[j]转移,则必须要保证 \([j+1,i]\) 内的点都与线 \(j\) 或线 \(i\) 相交,同时线 \(j\) 不能与线 \(i\) 相交。
对这个式子分析可以发现,从 \(1\) 到 \(n\) 的一个合法的转移序列中, \(p[i]\) 是递减的。即 \(p[i]\) 在 \(i\) 上递减。
或者说, \(i\) 在 \(p[i]\) 上递减。
那么可以以 \(p\) 维护一棵线段树,可以 \(O(\log(n))\) 查出合法最佳转移。
#include<bits/stdc++.h>
using namespace std;
const int N=210000,INF=0x7fffffff;
int nxt,n,p[N],w[N];
struct xds
{
int l,r,mn,mx,upmn;
}t[N*4];
void build(int p,int l,int r){
t[p].l=l; t[p].r=r;
t[p].mn=t[p].upmn=INF;
t[p].mx=-1;
if(l==r) return ;
int mid=(l+r)>>1;
build(p*2,l,mid);
build(p*2+1,mid+1,r);
}
int calc(int p,int nxt)
{
if(t[p].l==t[p].r)
return t[p].mx>nxt?t[p].mn:INF;
if(t[p*2+1].mx>nxt)
return min(t[p*2].upmn,calc(p*2+1,nxt));
return calc(p*2,nxt);
}
int query(int p,int l,int r)
{
int res=INF;
if(t[p].l>=l&&t[p].r<=r)
{
res=calc(p,nxt);
nxt=max(t[p].mx,nxt);
return res;
}
if(r>=t[p*2+1].l)
res=min(query(p*2+1,l,r),res);
if(l<=t[p*2].r)
res=min(query(p*2,l,r),res);
return res;
}
void insert(int p,int pos,int tail,int val){
if(t[p].l==t[p].r){
t[p].mn=val;
t[p].mx=tail;
return ;
}
if(pos<=t[p*2].r) insert(p*2,pos,tail,val);
else insert(p*2+1,pos,tail,val);
t[p].mx=max(t[p*2].mx,t[p*2+1].mx);
t[p].mn=min(t[p*2+1].mn,t[p*2].upmn=calc(p*2,t[p*2+1].mx));
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%d",&p[i]);
for(int i=1;i<=n;i++)
scanf("%d",&w[i]);
n++;
p[n]=n;
build(1,0,n+1);
insert(1,0,0,0);
for(int i=1,ans;i<=n;i++)
{
nxt=-1;
ans=query(1,0,p[i]-1)+w[i];
insert(1,p[i],i,ans);
if(i==n)
printf("%d\n",ans);
}
return 0;
}
T3 Lost My Music
这题首测卡题面没说的精度,大家纷纷炸成10分。
考场暴力50分。
作如下变形:
\(\frac{c_v-c_u}{dis(u,v)}=-\frac{c_u-c_v}{dep_u-dep_v}\)
如果把 \(c\) 看成横坐标,\(dep\)看成纵坐标,题目变成了一个实时维护斜率最大值的题。
维护一个下凸包,树上 \(dfs\),用单调栈维护凸包,每到达一个点,二分出该点在凸包上的插入位置,这时栈顶斜率即为该点答案。
回溯时把凸包改回原来的样子。
#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N=1100000;
long double ans[N];
int dep[N],head[N],cnt,zhan[N];
int n;
ll c[N];
struct bian
{
int nxt,to;
}b[N];
void add(int u,int v)
{
b[++cnt].to=v;
b[cnt].nxt=head[u];
head[u]=cnt;
}
long double K(int x,int y)
{
return (long double)(c[x]-c[y])/(long double)(dep[x]-dep[y]);
}
int get(int u,int r)
{
int l=2,mid;
long double k1,k2;
while(l<=r)
{
mid=(l+r)>>1;
k1=(long double)(-1)*K(zhan[mid],zhan[mid-1]);
k2=(long double)(-1)*K(zhan[mid],u);
if(k1<k2)
r=mid-1;
else
l=mid+1;
}
return l-1;
}
void dfs(int u,int fa,int top)
{
int k=get(u,top)+1,tmp1=zhan[k],tmp2=zhan[k-1];
if(u==1)
k=1;
ans[u]=(long double)(-1)*K(tmp2,u);
zhan[k]=u;
for(int i=head[u],v;i;i=b[i].nxt)
{
v=b[i].to;
if(v==fa)
continue;
dep[v]=dep[u]+1;
dfs(v,u,k);
}
zhan[k]=tmp1;
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%lld",&c[i]);
}
for(int i=2,a;i<=n;i++)
{
scanf("%d",&a);
add(a,i);
}
dep[1]=1;
dfs(1,0,0);
for(int i=2;i<=n;i++)
{
printf("%.10Lf\n",ans[i]);
}
return 0;
}
/*
8
31516 11930 18726 12481 79550 63015 64275 7608
1 1 2 4 2 4 5
*/
这次考试用脚出题……
下发文件上写着第一题没有SPJ,第二题有,实际相反。
T1题面说输出一行整数……害了多少人以为是走整数点路径。
T3卡精度后来又重测。
T3数据说的 \(500\) 内数据也残缺。
上一次考试T1还出了超出100%数据范围的数据,巨佬cyh搞了1h才发现。
20210716考试-NOIP16的更多相关文章
- 20210716考试-NOIP19
u,v,w. 这场考过. T1 u 差分裸题 #include<bits/stdc++.h> using namespace std; const int N=5000; int n,m; ...
- [Luogu 1850] noip16 换教室
[Luogu 1850] noip16 换教室 好久没有更博客了,先唠嗑一会,花了两天的空闲时间大致做完了昨年的noip真题 虽然在经过思考大部分题目都可出解(天天爱跑步除外),但是并不知道考试时候造 ...
- 全网独家MongoDB Certified DBA Associate考试认证视频
该视频意在让所有学员一次通过考试,避免重复考试而承担的巨额考试费用! 目前MongDB发展迅猛,有赶超mysql,和oracle看齐的苗头.在这个时候MongoDB也适时的推出了官方的认证考试&quo ...
- 记lrd的高二上学期第五次调研考试
河北某某中学的调研考试其实是很好玩的经历呢.可惜没有太多机会了. 背景: NOIP2016回来之后没有好好学文化课-.自习能翘就翘了,衡中特产学案自助没有好好写(说来我好像从来没被老师查到过,上课写学 ...
- 1009: [HNOI2008]GT考试
1009: [HNOI2008]GT考试 Time Limit: 1 Sec Memory Limit: 162 MB Description 阿申准备报名参加GT考试,准考证号为N位数\(X_1X_ ...
- mysql练习题-查询同时参加计算机和英语考试的学生的信息-遁地龙卷风
(-1)写在前面 文章参考http://blog.sina.com.cn/willcaty. 针对其中的一道练习题想出两种其他的答案,希望网友给出更多回答. (0) 基础数据 student表 +-- ...
- js封装用户选项传递给Servlet之考试系统二
<%@ page language="java" import="java.util.*" contentType="text/html; ch ...
- js动态生成选项之考试系统(一)
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"% ...
- 分享一个LiteDB做的简单考试系统辅助工具
凌晨,被安排在公司值班,因为台风“灿鸿”即将登陆,风力太大,办公楼,车间等重要部分需要关注.所以无聊,那就分享一下,今天给朋友临时做的一个小的考试系统辅助工具吧.其实非常小,需求也很简单,但是可以根据 ...
随机推荐
- 论文笔记:(2019)GAPNet: Graph Attention based Point Neural Network for Exploiting Local Feature of Point Cloud
目录 摘要 一.引言 二.相关工作 基于体素网格的特征学习 直接从非结构化点云中学习特征 从多视图模型中学习特征 几何深度学习的学习特征 三.GAPNet架构 3.1 GAPLayer 局部结构表示 ...
- 【LeetCode】34. 在排序数组中查找元素的第一个和最后一个位置
34. 在排序数组中查找元素的第一个和最后一个位置 知识点:数组,二分查找: 题目描述 给定一个按照升序排列的整数数组 nums,和一个目标值 target.找出给定目标值在数组中的开始位置和结束位置 ...
- 3D网页小实验-基于多线程和精灵动画实现RTS式单位行为
一.实验目的: 1.在上一篇的"RTS式单位控制"的基础上添加逻辑线程,为每个单位实现ai计算: 2.用精灵动画为单位的行为显示对应的动作效果. 二.运行效果: 1.场景中的单位分 ...
- js遍历终极大法--再也不用苦逼的for循环了
while循环 while后面跟循环条件和执行语句,只要满足条件,就会一直执行里面的执行 var i = 0 while(i<10){ console.log(i) i++ } do...whi ...
- NCB | 定量蛋白质组学揭示细胞外泌体通用标志物Syntenin-1
外泌体 (exosomes) 是由哺乳动物细胞通过"内吞-融合-外排"等机制,主动向胞外释放的纳米级 (直径40~60 nm) 双层囊泡小体,携带蛋白质.核酸.脂质等多种生物活性分 ...
- Apache Superset1.2.0教程(四)—— CentOS环境安装
前文中,我们已经在windows环境进行了superset的安装,也对图表功能进行了展示.但是在平时使用以及生产环境中,还是需要在centos环境下进行操作. 本文将带大家详解在centos7环境进行 ...
- Linux常见问题解决方案
1.Kali2020添加BCM43142的网卡驱动 来源:https://www.fujieace.com/kali-linux/wifi-drive.html 我只是执行了第三步:安装网卡驱动,即: ...
- 线程礼让_yield
线程礼让_yield 礼让线程,让当前正在执行的线程暂停,但不阻塞 将线程从运行状态转为就绪状态 让cpu重新调度,礼让不一定成功!看CPU心情 测试案例: package multithreadin ...
- (四)Linux之用户管理(用户和用户组)
Linux之用户管理(用户和用户组) 目录 Linux之用户管理(用户和用户组) 一.概述 二.用户和组的关系 三.关于UID和GID(用户ID和组ID) 四.用户和组的数据 /etc/passwd内 ...
- nacos项目搭建(服务提供者,服务消费者)
spring cloud ablibaba 版本说明 https://github.com/alibaba/spring-cloud-alibaba/wiki/版本说明 启动nacos服务 官网: h ...