正题

题目链接:https://www.ybtoj.com.cn/contest/116/problem/2


题目大意

\(n\)个点,\(x\)坐标递增,第\(i\)个点向第\(j\)个点连边。

开始一个人在点\(s\),他会向他看到过的\(y\)坐标最大的点的方向走(两个点之间能够看到当且仅当它们之间没有边或者点)。

求对于每个\(s\)走到\(y\)坐标最大的点的经过点数。

\(y\)值同样的以编号大的算大

\(1\leq n\leq 5\times 10^5,1\leq x_i,y_i\leq 10^6\)


解题思路

先考虑每个点能看到的最高的点。

维护一个前缀的上凸壳,然后每次把该点连接的那个点就是这个点在凸壳方向能看到的最高的点。

左右各做一次就好了。

然后考虑怎么处理答案,先把所有点按照目标点的高度排序,然后每个点找到它的方向上在它前面的第一个点作为它的真正目标点。然后倒序转移就好了。

找真正目标点的过程可以反过来然后用链表实现

时间复杂度\(O(n\log n)\)(写基排就\(O(n)\)了)


code

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<algorithm>
  4. #define ll long long
  5. using namespace std;
  6. const ll N=5e5+10;
  7. ll n,x[N],y[N],pos[N],s[N],l[N],r[N],p[N],f[N];
  8. ll xj(ll a,ll b,ll c){
  9. ll x1=x[b]-x[a],y1=y[b]-y[a];
  10. ll x2=x[c]-x[a],y2=y[c]-y[a];
  11. return x1*y2-x2*y1;
  12. }
  13. bool cmp(ll a,ll b){
  14. return y[p[a]]*n+p[a]<y[p[b]]*n+p[b];
  15. }
  16. signed main()
  17. {
  18. // freopen("mountain.in","r",stdin);
  19. // freopen("mountain.out","w",stdout);
  20. scanf("%lld",&n);
  21. for(ll i=1;i<=n;i++)
  22. scanf("%lld%lld",&x[i],&y[i]),pos[i]=i;
  23. ll top=0;s[++top]=1;
  24. for(ll i=2;i<=n;i++){
  25. while(top>1&&xj(s[top-1],s[top],i)>0)top--;
  26. p[i]=s[top];s[++top]=i;
  27. }
  28. top=1;s[top]=n;
  29. for(ll i=n-1;i>=1;i--){
  30. while(top>1&&xj(s[top-1],s[top],i)<0)top--;
  31. if(y[s[top]]>=y[p[i]])p[i]=s[top];s[++top]=i;
  32. }
  33. for(ll i=1;i<=n;i++)
  34. if(y[p[i]]*n+p[i]<y[i]*n+i)p[i]=0;
  35. y[0]=1e9;
  36. sort(pos+1,pos+1+n,cmp);
  37. for(ll i=1;i<=n;i++)
  38. l[i]=i-1,r[i]=i+1;
  39. for(ll i=1;i<n;i++){
  40. ll x=pos[i];
  41. if(p[x]>x)p[x]=r[x];
  42. else p[x]=l[x];
  43. l[r[x]]=l[x];r[l[x]]=r[x];
  44. }
  45. for(ll i=n-1;i>=1;i--){
  46. ll x=pos[i];
  47. f[x]=f[p[x]]+abs(p[x]-x);
  48. }
  49. for(ll i=1;i<=n;i++)
  50. printf("%lld\n",f[i]);
  51. return 0;
  52. }

YbtOJ#482-爬上山顶【凸壳,链表】的更多相关文章

  1. YbtOJ#853-平面标记【整体二分,凸壳】

    正题 题目链接:http://www.ybtoj.com.cn/contest/119/problem/3 题目大意 给出\(n\)个点\((x_i,y_i)\),\(m\)次给出\((k_i,a_i ...

  2. BZOJ 3672 [Noi2014]购票 (熟练剖分+凸壳维护)

    题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=3672 题意:给出一棵有根树(1为根),边有长度.每个点u有三个属性(len[u], ...

  3. bzoj 3165: [Heoi2013]Segment 动态凸壳

    3165: [Heoi2013]Segment Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 202  Solved: 89[Submit][Stat ...

  4. [BZOJ2726][SDOI2012]任务安排(DP+凸壳二分)

    2726: [SDOI2012]任务安排 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1580  Solved: 466[Submit][Statu ...

  5. bzoj 1007 凸壳

    首先明确一个概念 左面内个叫上凸壳,右面那个叫下凸壳 然后我们只需要维护一个上图壳就行了,先按着斜率排序,每次加进来一条边,判断tot边和这个边与tot-1边的交点横坐标, 如果这条边的横坐标小就一直 ...

  6. [Gym101982M][思维好题][凸壳]Mobilization

    [gym101982M][思维好题][凸壳]Mobilization 题目链接 20182019-acmicpc-pacific-northwest-regional-contest-div-1-en ...

  7. XVIII Open Cup named after E.V. Pankratiev. Grand Prix of Khamovniki Problem J Stairways解题报告(分块+维护凸壳)

    首先ORZ一发Claris聚聚的题解:http://www.cnblogs.com/clrs97/p/8689215.html,不然我可能没机会补过这道神题了. 这里写一个更详细的题解吧(我还是太菜了 ...

  8. bzoj2402 陶陶的难题II 分数规划+树剖+线段树维护凸壳+二分

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=2402 题解 看上去很像分数规划的模型.于是就二分吧.令 \[ \begin{align*}\f ...

  9. 【JZOJ3299】【SDOI2013】保护出题人 三分+凸壳

    题面 ​出题人铭铭认为给SDOI2012 出题太可怕了,因为总要被骂,于是他又给SDOI2013 出题了. 参加SDOI2012 的小朋友们释放出大量的僵尸,企图攻击铭铭的家.而你作为SDOI2013 ...

随机推荐

  1. uwp 之吐司 toast

    Toast -------------------------------------------------------------- var t = Windows.UI.Notification ...

  2. Quartz任务调度(4)JobListener分版本超详细解析

    JobListener 我们的jobListener实现类必须实现其以下方法: 方法 说明 getName() getName() 方法返回一个字符串用以说明 JobListener 的名称.对于注册 ...

  3. 同步(synchronized)

    转载至:https://www.cnblogs.com/dolphin0520/p/3923737.html 一.什么时候会出现线程安全问题? 在单线程中不会出现线程安全问题,而在多线程编程中,有可能 ...

  4. Ubuntu防火墙:ufw

    原始linux的防火墙是iptables,以为过于繁琐,各个发行版几乎都有自己的方案; ubuntu下的防火墙是ufw[ubuntu fireward的缩写],centos的防火墙是fireward ...

  5. Jsoup学习笔记

    时间:2016-7-7 00:05 jsoup 是一款 Java 的HTML 解析器,可直接解析某个URL地址.HTML文本内容.它提供了一套非常省力的API,可通过DOM,CSS以及类似于JQuer ...

  6. springcloud<zuul过滤器简单配置与跨域设置>

    package com.wangbiao.config; import com.netflix.zuul.ZuulFilter; import com.netflix.zuul.context.Req ...

  7. docker《三》单机部署项目容器,nginx负载均衡

    接着<二> 创建一个网段(和二在一个网段) docker network create --subnet=172.19.0.0/24 pro-net docker run -d --nam ...

  8. Nginx配置文件详解与优化建议

    1.概述 今天来详解一下Nginx的配置文件,以及给出一些配置建议,希望能对大家有所帮助. 2.nginx.conf 1)配置文件位置 nginx 安装目录的 conf 文件夹下,例如:/usr/lo ...

  9. Selenium4 IDE初体验

    今天闲来无事,尝试了一番Selenium4的IDE,提供了录制和回放的功能.下面是对它的简单介绍. 安装 下载地址:https://www.selenium.dev/selenium-ide/ 在下载 ...

  10. 操作系统的IO模型

    IO操作根据设备类型一般分为内存IO,网络IO,和磁盘IO.其中内存IO的速度大大快于后两者,计算机的性能瓶颈一般不在于内存IO. 尽管网络IO可通过购买独享带宽和高速网卡来提升速度,可以使用RAID ...