Nested Segments CodeForces - 976C (思维)

本文介绍了一种寻找一个区间是否完全包含另一个区间的算法。通过将区间按起始点升序排序,并在相同起始点时按终点降序排列的方法,实现高效查找。最后给出了完整的C++代码实现。

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

C. Nested Segments
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

You are given a sequence a1, a2, ..., an of one-dimensional segments numbered 1 through n. Your task is to find two distinct indices i and j such that segment ai lies within segment aj.

Segment [l1, r1] lies within segment [l2, r2] iff l1 ≥ l2 and r1 ≤ r2.

Print indices i and j. If there are multiple answers, print any of them. If no answer exists, print -1 -1.

Input

The first line contains one integer n (1 ≤ n ≤ 3·105) — the number of segments.

Each of the next n lines contains two integers li and ri (1 ≤ li ≤ ri ≤ 109) — the i-th segment.

Output

Print two distinct indices i and j such that segment ai lies within segment aj. If there are multiple answers, print any of them. If no answer exists, print -1 -1.

Examples
input
Copy
5
1 10
2 9
3 9
2 3
2 9
output
Copy
2 1
input
Copy
3
1 5
2 6
6 20
output
Copy
-1 -1
Note

In the first example the following pairs are considered correct:

  • (2, 1), (3, 1), (4, 1), (5, 1) — not even touching borders;
  • (3, 2), (4, 2), (3, 5), (4, 5) — touch one border;

  • (5, 2), (2, 5) — match exactly.

题意:给出n个区间[l,r],问是否有一个区间包含另一个区间,如果有,输出被包含的区间的包含区间的下标,否则输出-1 -1

思路:按l的升序排序,如果l相等,那么r大的在前面,然后从左到有,依次比较第i和i-1个即可

#include "iostream"
#include "algorithm"
using  namespace std;
struct P
{
    int first,second,index;
};
const int Max=3e5+10;
P seg[Max];
bool cmp(P a,P b)
{
    if(a.first<=b.first){
        if(a.first==b.first) return a.second>b.second;
        else return 1;
    }
    else
        return 0;
}
int main()
{
    ios::sync_with_stdio(false);
    int n,flag=0;
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>seg[i].first>>seg[i].second;
        seg[i].index=i+1;
    }
    sort(seg,seg+n,cmp);
    for(int i=1;i<n;i++){
        if(seg[i].second<=seg[i-1].second){
            flag=1;
            cout<<seg[i].index<<" "<<seg[i-1].index<<endl;
            break;
        }
    }
    if(!flag)
        cout<<"-1 -1"<<endl;
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值