uva 1398 Meteor

https://vjudge.net/problem/UVA-1398

!!!:uvalive炸了,简直有毒,标程提交都有错。

题意:

一个矩形的相机,左下坐标是(0,0),右上坐标是(w,h),在这个坐标系内,有许多正在飞的流星,每个流星用两个向量表示,一个表示初始位置,另一个表示速度向量,问照相机范围内星星最多的时候有多少颗。

在相机边界的点是不在相机范围内的。(即为开区间。)

思路:

扫描线的第一道题。。。参考训练指南。

首先,流星在照相机范围内是有一个时间范围的,于是问题遍转化成了在哪个时刻照相机范围内的流行最多,那么转化成数学问题就是流星在相机内的时间段转换成数轴上的一个个区间,那么我们用垂直于数轴的一根直线去扫数轴,那么在某一个区间范围内,

这根直线与一定数量的区间相交,并且这个区间的数量最大,那么这就是可以看到流星的最大数量。

时间范围用不等式求解,0 < at + x < w,0 < bt + y < h行(开区间),那个update函数的作用就是这个,理解了相当长的一段时间。。。

那么对于每一个流星的时间段,可以拆分成一个开始事件和一个结束事件,然后把每个流星排序,假设排好了序,那么当统计数量的时候,遇到了一个开始事件,就把数量加一,遇到了一个结束事件,那么就把数量减一,这样一边遍历,一边维护。

接下来,讲讲排序的问题,当遇到一个事件的结束和一个事件的开始时间相同的时候,应该把哪个排在前面呢?

因为是开区间,而此时开始的那个事件还未进入相机,但是结束的那个事件已经不再相机之中了,所以在排序的时候,如果说时间相同,那么把结束事件排在前面,把开始事件排在后面。

还有计算时间的时候,如果速度为0,并且坐标不在给定的范围内的,那么就不应该计算这颗流星。(记住是 || 不是 && 在这里debug半天,最近老是写炸Orz)

代码:

 1 #include <stdio.h>
 2 #include <string.h>
 3 #include <algorithm>
 4 using namespace std;
 5 
 6 void caltime(int x,int a,int w,double &l,double &r)
 7 {
 8     if (a == 0)
 9     {
10         if (x <= 0 || x >= w) l = 1e10,r = 0;
11     }
12     else if (a > 0)
13     {
14         l = max(l,-(double) x / a);
15         r = min(r,(double)(w - x) / a);
16     }
17     else
18     {
19         l = max(l,(double)(w - x) / a);
20         r = min(r,-(double)x / a);
21     }
22 }
23 
24 struct node
25 {
26     double x;
27     int ty;
28 } c[200005];
29 
30 bool cmp(node aa,node bb)
31 {
32     if (aa.x == bb.x) return aa.ty < bb.ty;
33     return aa.x < bb.x;
34 }
35 
36 int main()
37 {
38     int t;
39 
40     scanf("%d",&t);
41 
42     while (t--)
43     {
44         int w,h;
45 
46         scanf("%d%d",&w,&h);
47 
48         int n;
49 
50         scanf("%d",&n);
51 
52         int cnt = 0;
53 
54         for (int i = 0;i < n;i++)
55         {
56             int x,y,a,b;
57 
58             scanf("%d%d%d%d",&x,&y,&a,&b);
59 
60             double l = 0,r = 1e10;
61 
62             caltime(x,a,w,l,r);
63 
64             caltime(y,b,h,l,r);
65 
66             //if (y == h && b == 0) printf("**");
67 
68             if (l < r)
69             {
70                 //printf("%f %f\n",l,r);
71                 c[cnt++] = (node){l,1};
72                 c[cnt++] = (node){r,0};
73             }
74         }
75 
76         sort(c,c+cnt,cmp);
77 
78         int ans = 0;
79 
80         int num = 0;
81 
82         for (int i = 0;i < cnt;i++)
83         {
84             //printf("%f %d **\n",c[i].x,c[i].ty);
85 
86             if (c[i].ty == 0) num--;
87             else num++;
88 
89             ans = max(ans,num);
90         }
91 
92         printf("%d\n",ans);
93     }
94 
95     return 0;
96 }

 

转载于:https://www.cnblogs.com/kickit/p/7622911.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 该资源内项目源码是个人的课程设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值