洛谷 P3256 [JLOI2013]赛车【半平面交??一次函数互相覆盖的判断】

本文介绍了一道名为“赛车”的算法题,该题要求参赛者通过给定的赛车初始位置和速度来确定哪些赛车最终能获得奖项。文章提供了完整的C++代码实现,并详细解释了输入输出格式及数据范围。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【表示感觉跟那个水平可见直线一样。。。】
P3256 [JLOI2013]赛车
题目描述
这里有一辆赛车比赛正在进行,赛场上一共有N辆车,分别称为个g1,g2……gn。赛道是一条无限长的直线。最初,gi位于距离起跑线前进ki的位置。比赛开始后,车辆gi将会以vi单位每秒的恒定速度行驶。在这个比赛过程中,如果一辆赛车曾经处于领跑位置的话(即没有其他的赛车跑在他的前面),这辆赛车最后就可以得奖,而且比赛过程中不用担心相撞的问题。现在给出所有赛车的起始位置和速度,你的任务就是算出那些赛车将会得奖。

输入格式:
第一行有一个正整数N表示赛车的个数。接下来一行给出N个整数,按顺序给出N辆赛车的起始位置。再接下来一行给出N个整数,按顺序给出N辆赛车的恒定速度。

输出格式:
输出包括两行,第一行为获奖的赛车个数。第二行按从小到大的顺序输出获奖赛车的编号,编号之间用空格隔开,注意最后一个编号后面不要加空格。

输入样例#1:
4
1 1 0 0
15 16 10 20
输出样例#1:
3
1 2 4

对于100%的数据N<=10000, 0<=ki<=10^9, 0<=vi<=10^9

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
const int N=100005;
int n,d,z[N];
struct ss{
    int x,y,z;
}a[N];bool flag[N];
//Writer : SM
bool cmp(ss x,ss y){return x.x<y.x||x.x==y.x&&x.y<y.y;}
bool cmp1(int x,int y){return a[x].z<a[y].z;}
double X(int x,int y){
    double xx=double(a[x].y-a[y].y)/(a[y].x-a[x].x);
    return xx;
}bool pd(int x,int y,int z){
    double xx=X(x,y);
    double yy=X(x,z);
    return xx>yy;
}
int main(){
    scanf("%d",&n);
    for(int i=1;i<=n;i++){
        a[i].z=i;
        scanf("%d",&a[i].y);
    }for(int i=1;i<=n;i++)
        scanf("%d",&a[i].x);
    sort(a+1,a+n+1,cmp);
    for(int i=1;i<=n;i++){
        while(d>=1&&X(z[d],i)<0)d--;
        while(d>=2&&pd(z[d-1],z[d],i))d--;
        z[++d]=i;
    }sort(z+1,z+d+1,cmp1);
    printf("%d\n",d);
    for(int i=1;i<=d;i++)
        printf("%d ",a[z[i]].z);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GoesM

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值