咕咕咕。    camp补题。

传送门:https://www.zhixincode.com/contest/29/problems

A.Aqours

题意:有一棵有根树,根节点为1,给出每个结点的父亲节点。其中根节点是 1 号点。i号结点的父亲为pi。保证1<=pi,而且对于2<=i<j<=n,有pi<=pj。

问对于每一个叶子节点,与编号比他小的叶子结点的最近距离是什么?

分析:根据题意可以将给定的点序列看为BFS序。对于每一个结点u,可以维护一个f[u]代表距离点u的最近叶子结点的距离。

那么,每次遇到一个叶子结点,就暴力向上搜,在搜的过程中,更新f值,直至搜到一个被更新过的结点,即被其他叶子结点搜过的点。

每碰到一个被搜过的点xx,那么对于当前这个叶子节点来说,答案就是f[xx]+搜到xx的步数。

同时还需要在回溯的过程中,更新每个点的距离叶子节点的最短距离。

#include<bits/stdc++.h>
using namespace std;
const int maxn=3e6+;
const int inf=0xfffffff;
int outd[maxn],f[maxn],fa[maxn],vis[maxn];
int ff;
int dfs(int xx,int step){
if (vis[xx]){ff=f[xx]+step;return f[xx]+;}
vis[xx]=; f[xx]=step;
int tmp=inf;
if (xx!=) tmp=dfs(fa[xx],++step);
f[xx]=min(f[xx],tmp);
return f[xx]+;
}
int main(){
int n,x; scanf("%d",&n);
memset(outd,,sizeof(outd));
for (int i=;i<=n;i++){
scanf("%d",&x);
fa[i]=x;
outd[x]++;
}
for (int i=;i<=n;i++) vis[i]=;
for (int i=;i<=n;i++){
if (outd[i]==){
ff=;
dfs(i,);
if (ff!=) printf("%d %d\n",i,ff);
else printf("%d -1\n",i);
}
}
return ;
} /*反例:
10
1 1 1 2 2 2 5 7 8 答案:
3 -1
4 2
6 3
9 3
10 4
*/

A.Aqours

C.御坂妹妹

题意:有n条直线,以y=kx+b的形式给出。求解一个垂直于x轴的线段,要求和这n条直线都有交点。问所求线段的最短距离了是多少。

分析:通过画图,可以观察到,可以维护这n条直线所形成的,一个在直线上方的凸包,一个在直线下方的凸包。答案一定是在所求的凸包点的x值处。

(也不完全是凸包,eg.样例。。类似于凸壳。

题解还有一种做法是:

不是很懂扫描线的操作。(雾

另:(男朋友是神仙.jpg

 #include<bits/stdc++.h>
using namespace std;
const int maxn=5e5+;
struct line{
double k,b;
}ll[maxn],sta1[maxn],sta2[maxn];
double st1[maxn],st2[maxn];
int n;
bool cmp1(line p,line q){return p.k<q.k || p.k==q.k && p.b>q.b;}
bool cmp2(line p,line q){return p.k>q.k || p.k==q.k && p.b<q.b;}
double calc(line l1,line l2){return (l2.b-l1.b)/(l1.k-l2.k);}
bool check(line a,line b,line L){
if (calc(a,L)<=calc(a,b)) return true;
return false;
}
void solve(line sta[],double st[],int &num){
int top=;
for (int i=;i<n;i++){
if (top<){sta[++top]=ll[i]; continue;}
if (ll[i].k==ll[i-].k) continue;
while (top> && check(sta[top-],sta[top],ll[i])) top--;
sta[++top]=ll[i];
}
num=;
for (int i=;i<=top;i++){
double xx=calc(sta[i],sta[i-]);
st[++num]=xx;
}
st[++num]=1e9;
}
set<double> aa;
int main(){
scanf("%d",&n);
double max_=-1e9,min_=1e9;
for (int i=;i<n;i++) scanf("%lf%lf",&ll[i].k,&ll[i].b),aa.insert(ll[i].k),
max_=max(ll[i].b,max_),min_=min(ll[i].b,min_);
if (aa.size()==) return printf("%.10f\n",max_-min_),;
//
sort(ll,ll+n,cmp1); int num1=;
solve(sta1,st1,num1);
//
sort(ll,ll+n,cmp2); int num2=;
solve(sta2,st2,num2); double ans=1e20;
for (int i=;i<num1;i++){
int xx=upper_bound(st2+,st2++num2,st1[i])-st2;
double tmp=fabs(sta1[i].k*st1[i]+sta1[i].b-sta2[xx].k*st1[i]-sta2[xx].b);
ans=min(ans,tmp);
}
for (int i=;i<num2;i++){
int xx=upper_bound(st1+,st1++num1,st2[i])-st1;
double tmp=fabs(sta2[i].k*st2[i]+sta2[i].b-sta1[xx].k*st2[i]-sta1[xx].b);
ans=min(ans,tmp);
}
printf("%.10f\n",ans);
return ;
}

C

(wa了好多发的题。傻逼错误。我是智障.jpg

CCPC-Wannafly Winter Camp Day8 (Div2, onsite)的更多相关文章

  1. Wannafly Winter Camp Day8(Div1,onsite) E题 Souls-like Game 线段树 矩阵乘法

    目录 Catalog Solution: (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 Catalog @ Problem:传送门  Portal  原题目描述在最下面.  简单的 ...

  2. CCPC-Wannafly Winter Camp Day8 (Div2, onsite) A 题 Aqours (精巧的树形DP)

    题目链接: https://www.cometoj.com/contest/29/problem/A?problem_id=414 Aqours 题目描述 Aqours 正在 LoveLive! 决赛 ...

  3. CCPC-Wannafly Winter Camp Day8 (Div2, onsite) 补题

    A Aqours 题解: https://www.cnblogs.com/qieqiemin/p/11251645.html D:吉良吉影的奇妙计划 (暴力打表) 题目描述 吉良吉影是一个平凡的上班族 ...

  4. 2020 CCPC Wannafly Winter Camp Day1 C. 染色图

    2020 CCPC Wannafly Winter Camp Day1 C. 染色图 定义一张无向图 G=⟨V,E⟩ 是 k 可染色的当且仅当存在函数 f:V↦{1,2,⋯,k} 满足对于 G 中的任 ...

  5. CCPC Wannafly Winter Camp Div2 部分题解

    Day 1, Div 2, Prob. B - 吃豆豆 题目大意 wls有一个\(n\)行\(m\)列的棋盘,对于第\(i\)行第\(j\)列的格子,每过\(T[i][j]\)秒会在上面出现一个糖果, ...

  6. CCPC-Wannafly Winter Camp Day5 (Div2, onsite) Sorting(线段树)

    题目链接 题意 对序列进行三种操作: 1.区间求和. 2.将区间小于等于$x$的数不改变相对顺序的前提下放到$x$左边,用同样规则将比$x$大的放到右边. 3.将区间大于$x$的数不改变相对顺序的前提 ...

  7. CCPC-Wannafly Winter Camp Day3 (Div2, onsite)

    Replay Dup4: 没想清楚就动手写? 写了两百行发现没用?想的还是不够仔细啊. 要有莽一莽的精神 X: 感觉今天没啥输出啊, 就推了个公式?抄了个板子, 然后就一直自闭A. 语文差,题目没理解 ...

  8. 2019 CCPC-Wannafly Winter Camp Day1 (Div2, onsite)

    solve:4/11 补题:6/11 A 机器人 补题:zz 这是一道分类讨论的题目,有一个规律就是如果必须要从第一个区到第二个区,那么最多转区两次(1到2一次,2到1一次),然后分类讨论即可,只要细 ...

  9. 2019 CCPC-Wannafly Winter Camp Day7(Div2, onsite)

    solve 6/11 补题: A.迷宫 Code:zz Thinking:zz kk 把每个节点的深度都处理出来,同一深度的点的冲突度为 (x-1),x为同层次点数减一. 然后冲突度不断下传(冲突度为 ...

随机推荐

  1. 深入剖析GPU Early Z优化

    最近在公司群里同事发了一个UE4关于Mask材质的优化,比如在场景中有大面积的草和树的时候,可以在很大程度上提高效率.这其中的原理就是利用了GPU的特性Early Z,但是它的做法跟我最开始的理解有些 ...

  2. JMM中的重排序及内存屏障

    目录 1. 概述 2. 重排序 2-1. as-if-serial语义 2-2. 重排序的种类 2-3. 从Java源代码到最终实际执行的指令序列, 会分别经历下面3中重排序. 3. 内存屏障类型 3 ...

  3. SQL Server 中的6种事务隔离级别简单总结

    本文出处:http://www.cnblogs.com/wy123/p/7218316.html (保留出处并非什么原创作品权利,本人拙作还远远达不到,仅仅是为了链接到原文,因为后续对可能存在的一些错 ...

  4. node起一个简单服务,打开本地项目或文件浏览

    1.安装nodejs 2.在项目文件夹目录下创建一个js文件,命名server.js(自定义名称),内容如下 var http = require('http'); var fs = require( ...

  5. 微信小程序---人脸识别(wx.startFacialRecognitionVerify)

    1.由于人脸核验功能涉及到用户的敏感.隐私信息,因此调用此接口的业务方,需要满足一定的条件,申请小程序的人脸识别api.开通小程序后台的接口权限入口后,开发者可以登录mp.weixin.qq.com小 ...

  6. App后台Keynote

    [App后台Keynote] 一.基础. 1.一个 节省 流量 的 处理 方法 是 让 App 下载 经过 压缩 的 图片( 一般 是 几十 KB 以下), 当 用户 需要 查看 原图 时 才 下载 ...

  7. Codeforces Round #508 (Div. 2)

    Codeforces Round #508 (Div. 2) http://codeforces.com/contest/1038 A #include<bits/stdc++.h> us ...

  8. Curator的cluster,实现多节点数据共享

    模拟两个客户端,实现多节点数据共享 package bjsxt.curator.cluster; import org.apache.curator.RetryPolicy; import org.a ...

  9. 校验金额、大小写字母、大写字母、合法uri、email

    /* 合法uri*/ export function validURL(url) { const reg = /^(https?|ftp):\/\/([a-zA-Z0-9.-]+(:[a-zA-Z0- ...

  10. Python开发——函数【装饰器、高阶函数、函数嵌套、闭包】

    装饰器 装饰器本质就是函数,为其他函数添加附加功能. 原则: 不修改被修饰函数的源代码 不修改被修饰函数的调用方法 装饰器知识储备:装饰器 = 高阶函数 + 函数嵌套 + 闭包 案例:求函数运行时间! ...