题意:给一些直线,问这些直线在直线x=L,x=R之间有多少个交点。

讲解见此文:http://blog.sina.com.cn/s/blog_778e7c6e0100q64a.html

首先将直线分别跟x=L+eps,x=R-eps(防止出现相同纵坐标,故+-eps)求他们的交点,求的纵坐标为low,high,首先按low从大到小排序,一次赋予一个ind值,再按high从大到小排序,此时ind的逆序对数即为(L,R)内的交点个数。成功将计算几何问题向树状数组转化。求逆序对数可用归并排序或者树状数组解决。

代码:(树状数组)

  1. #include <iostream>
  2. #include <cmath>
  3. #include <iostream>
  4. #include <cstdio>
  5. #include <cstring>
  6. #include <cstdlib>
  7. #include <cmath>
  8. #include <algorithm>
  9. #define eps 1e-5
  10. using namespace std;
  11. #define N 10007
  12.  
  13. struct node
  14. {
  15. double x,y;
  16. };
  17.  
  18. struct Line
  19. {
  20. node a,b;
  21. int ind;
  22. double low,high;
  23. }line[N];
  24.  
  25. int c[N],n;
  26.  
  27. int cmp(Line ka,Line kb)
  28. {
  29. return ka.low > kb.low;
  30. }
  31.  
  32. int cmp2(Line ka,Line kb)
  33. {
  34. return ka.high > kb.high;
  35. }
  36.  
  37. int lowbit(int x){ return x & (-x); }
  38.  
  39. void modify(int x)
  40. {
  41. while(x <= n)
  42. c[x]++,x += lowbit(x);
  43. }
  44.  
  45. int getsum(int x)
  46. {
  47. int res = ;
  48. while(x > )
  49. res += c[x],x -= lowbit(x);
  50. return res;
  51. }
  52.  
  53. int main()
  54. {
  55. int i,x,j;
  56. double L,R;
  57. while(scanf("%d",&n)!=EOF)
  58. {
  59. memset(c,,sizeof(c));
  60. for(i=;i<=n;i++)
  61. scanf("%lf%lf%lf%lf",&line[i].a.x,&line[i].a.y,&line[i].b.x,&line[i].b.y);
  62. scanf("%lf%lf",&L,&R);
  63. L += eps,R -= eps;
  64. for(i=;i<=n;i++)
  65. {
  66. double k = (line[i].b.y-line[i].a.y)/(line[i].b.x-line[i].a.x);
  67. line[i].low = k*(L-line[i].a.x) + line[i].a.y;
  68. line[i].high = k*(R-line[i].a.x) + line[i].a.y;
  69. }
  70. sort(line+,line+n+,cmp);
  71. for(i=;i<=n;i++)
  72. line[i].ind = i;
  73. sort(line+,line+n+,cmp2);
  74. int ans = ;
  75. for(i=;i<=n;i++)
  76. {
  77. modify(line[i].ind);
  78. ans += i - getsum(line[i].ind);
  79. }
  80. printf("%d\n",ans);
  81. }
  82. return ;
  83. }

ZOJ 3157 Weapon --计算几何+树状数组的更多相关文章

  1. ZOJ 2112 Dynamic Rankings(树状数组+主席树)

    The Company Dynamic Rankings has developed a new kind of computer that is no longer satisfied with t ...

  2. CF1446F-Line Distance【计算几何,树状数组,二分】

    正题 题目链接:https://www.luogu.com.cn/problem/CF1446F 题目大意 给出\(n\)个点,求所有点对构成的直线中与原点距离第\(k\)小的距离 \(2\leq n ...

  3. ZOJ - 2112 主席树套树状数组

    题意:动态第k大,可单点更新,操作+原数组范围6e4 年轻人的第一道纯手工树套树 静态第k大可以很轻易的用权值主席树作差而得 而动态第k大由于修改第i个数会影响[i...n]棵树,因此我们不能在原主席 ...

  4. [BZOJ 3295] [luogu 3157] [CQOI2011]动态逆序对(树状数组套权值线段树)

    [BZOJ 3295] [luogu 3157] [CQOI2011] 动态逆序对 (树状数组套权值线段树) 题面 给出一个长度为n的排列,每次操作删除一个数,求每次操作前排列逆序对的个数 分析 每次 ...

  5. Dynamic Rankings ZOJ - 2112(主席树+树状数组)

    The Company Dynamic Rankings has developed a new kind of computer that is no longer satisfied with t ...

  6. ZOJ 2112 Dynamic Rankings(树状数组套主席树 可修改区间第k小)题解

    题意:求区间第k小,节点可修改 思路:如果直接用静态第k小去做,显然我更改一个节点后,后面的树都要改,这个复杂度太高.那么我们想到树状数组思路,树状数组是求前缀和,那么我们可以用树状数组套主席树,求出 ...

  7. ZOJ 2112 Dynamic Rankings(树状数组+主席树)

    题意 \(n\) 个数,\(m\) 个操作,每次操作修改某个数,或者询问某个区间的第 \(K\) 小值. \(1 \leq n \leq 50000\) \(1 \leq m \leq 10000\) ...

  8. ZOJ 2112 Dynamic Rankings (动态第k大,树状数组套主席树)

    Dynamic Rankings Time Limit: 10 Seconds      Memory Limit: 32768 KB The Company Dynamic Rankings has ...

  9. ZOJ 3635 Cinema in Akiba (第一次组队) 树状数组+二分

    Cinema in Akiba Time Limit: 3 Seconds      Memory Limit: 65536 KB Cinema in Akiba (CIA) is a small b ...

随机推荐

  1. PHP redis Api 中文文档

    phpredis是php的一个扩展,效率是相当高有链表排序功能,对创建内存级的模块业务关系 很有用;以下是redis官方提供的命令使用技巧: 下载地址如下: https://github.com/ow ...

  2. 使用Jsoup解析html网页

    一.   JSOUP简介 在以往用java来处理解析HTML文档或者片段时,我们通常会采用htmlparser(http://htmlparser.sourceforge.net/)这个开源类库.现在 ...

  3. .NET Core Roadmap

    This post was written by Scott Hunter. It has been about two weeks since we shipped .NET Core / ASP. ...

  4. SFTP和FTS协议的区别

    都是为FTP连接加密,协议非常相似.一个是借助SSL协议加密,一个时借助SSH协议加密.SSL是为HTTP/SMTP等加密设计的:SSH是为TELNET/FTP等加密.建立传输通道而设计的.其实SSH ...

  5. Web前端小白入门指迷

    前注:这篇文章首发于我自己创办的服务于校园的技术分享 [西邮 Upper -- 004]Web前端小白入门指迷,写得很用心也就发在这里. 大前端之旅 大前端有很多种,Shell 前端,客户端前端,Ap ...

  6. 一个页面从输入 URL 到页面加载完的过程中都发生了什么事情?

    过程概述 浏览器查找域名对应的 IP 地址: 浏览器根据 IP 地址与服务器建立 socket 连接: 浏览器与服务器通信: 浏览器请求,服务器处理请求: 浏览器与服务器断开连接. 以下为详细解析: ...

  7. 初学Node(六)搭建一个简单的服务器

    搭建一个简单的服务器 通过下面的代码可以搭建一个简单的服务器: var http = require("http"); http.createServer(function(req ...

  8. 访问SAP的Domain的Value Range

    访问Domain的Value Range有两种方法: 1.直接访问表 dd07l和dd07T     select * from dd07l            where domname   = ...

  9. 迭代器iterator(三):Listlterator遍历arraylist,并用逆序输出结果

    迭代器(iterator) 是一种对象,它能够用来遍历标准模板库容器中的部分或全部元素,每个迭代器对象代表容器中的确定的地址.迭代器修改了常规指针的接口,所谓迭代器是一种概 念上的抽象:那些行为上像迭 ...

  10. IOS SizeClasses 详解

    SizeClasses 详解 iOS 8在应用界面的可视化设计上添加了一个新的特性-Size Classes.对于任何设备来说,界面的宽度和高度都只分为三种描述:紧凑,任意和宽松.这样开发者便可以无视 ...