`

8602 区间相交问题

 
阅读更多

8602 区间相交问题(必做)

时间限制:1000MS  内存限制:1000K
提交次数:1966 通过次数:468

题型: 编程题   语言: C++;C;VC;JAVA

Description

给定x轴上n个闭区间,去掉尽可能少的闭区间,使剩下的闭区间都不相交。

注意:这里,若区间与另一区间之间仅有端点是相同的,不算做区间相交。例如,[1,2]和[2,3]算是不相交区间。 


输入格式

第一行一个正整数n(n<=50),表示闭区间数。接下来n行中,每行2个整数,表示闭区间的2个整数端点。



输出格式

输出去掉的最少的闭区间数。



输入样例

3
10 20
10 15
12 15


输出样例

2

 

这个问题基本等同于书本的活动安排问题。

网上的一种用了pair,所以写得有点恶心。记住 second 是左端点, first 才是右端点就行了。
#include <iostream>
#include <utility>
#include <algorithm>
using namespace std;
int main()
{
    int n;
    while(cin>>n)
    {
        pair<int,int> p[n];
        for(int i=0; i<n; i++)
        {
            cin >> p[i].second;
            cin >> p[i].first;
            if(p[i].second > p[i].first)
            {
                swap(p[i].second, p[i].first);
            }
        }
        sort(p, p+n);
        int last, cnt;
        last = p[0].first;
        cnt = 1;
        for(int i=1; i<n; i++)
        {
            if(p[i].second >= last)
            {
                cnt++;
                last = p[i].first;
            }
        }
        cout << n - cnt << endl;
    }
    return 0;
}
第二种:
#include <iostream> 
#include <string.h>
#include <algorithm>//c++ sort
using namespace std;
int cmp( const int &a, const int &b ){
if( a > b )
return 1;
else
return 0;
}// sort(a,a+n,cmp);
struct Extent
{
    int a,b;
    bool operator < (const Extent& S)const
    {
        return b < S.b;
    }
}B[10002];

int main()
{
    int s[100];
    int f[100];
    int n,m;
    cin >>n;
    m=n;
    for(int i=1;m>0;i++,m--){
        cin >>B[i].a;
        cin >>B[i].b;
    }
    sort(B,B+n);

 //   int A[100];
   // memset(A,0,100*sizeof(int));
     int sum=0;
    int end = -1;
    for(int i=1;i<=n;i++){
        if(end<=B[i].a){
            end=B[i].b;
            sum++;
        }
    }


    cout << n-sum << endl;
    return 0;
}
第三种:#include <iostream>
#include <stdio.h>
using namespace std;
int n;
int s[100];
int e[100];
void myS(){
    for(int i=0;i<n;i++){
        for(int j=i;j<n;j++){
            if(e[i]>e[j]){  //注意是比较结束时间
                int temp = s[i];
                s[i] = s[j];
                s[j] = temp;
                temp = e[i];
                e[i] = e[j];
                e[j] = temp;
            }
        }
    }
}
int main()
{
    freopen("in.txt","r",stdin);
    cin >> n;
    for(int i=0;i<n;i++)
        cin >> s[i] >> e[i];
    myS();
    int num =1; // 注意num 至少为1
    int ee = e[0];  //假定第一个为标准
    for(int i=1;i<n;i++){
            if(ee<=s[i]){  //注意是>= 边界问题
                num++;
                ee = e[i];
            }
        }
    cout << n-num << endl;
    return 0;
}

 

分享到:
评论

相关推荐

    8602区间相交问题

    注意:这里 若区间与另一区间之间仅有端点是相同的 不算做区间相交 例如 [1 2]和[2 3]算是不相交区间 输入格式 第一行一个正整数n n&lt; 50 表示闭区间数 接下来n行中 每行2个整数 表示闭区间的2个整数端点 ...

    区间相交问题

    ### 区间相交问题详解 #### 一、问题背景及定义 在计算机科学与算法设计领域中,区间相交问题是一类常见的问题。这类问题通常涉及到如何处理多个区间之间的关系,比如判断区间是否相交、计算相交部分的长度等。本...

    不相交的闭区间的并

    给定n个闭区间[ai, bi](1 ),这些区间的并可以表示为一些不相交的闭区间的并。要求在这些表示方式中找出包含不相交区间数目最少的方案。 【输入形式】 输入文件为当前目录下的prz.in。 该文件的第一行包含一个...

    贪心思想的区间覆盖问题

    情形1:区间完全覆盖问题 情形2:最大不相交区间数问题 情形3:区间选点问题

    区间调度问题

    4. 在处理冲突时,需要确保新加入的区间不会与已选的区间相交。 5. 记录并返回最后能够安排的区间数量。 总之,区间调度问题是一个典型的计算机科学问题,它展示了贪心算法和动态规划在解决实际问题中的应用。通过...

    区间树查找区间算法的实现

    区间树是一种数据结构,主要用于高效地处理一系列区间查询和操作,比如查找与特定点相交的区间、查找覆盖某一区间的最小区间等。在计算机科学中,它在图形学、数据库、调度算法等多个领域有广泛应用。这个压缩包文件...

    java-leetcode面试题解哈希表第352题将数据流变为多个不相交区间-题解.zip

    本题解主要关注的是哈希表的运用,具体是LeetCode中的第352题——"数据流中的不相交区间"。这个题目涉及到数据结构、动态规划以及哈希表的高效操作,因此对于理解和掌握这些知识点具有很高的价值。 哈希表是一种...

    带权区间图的最短路算法

    2. **区间交集**: 区间\(I\)和区间\(J\)相交当且仅当\(I \cap J \neq \emptyset\)。 3. **区间集合** \(S\): 由\(n\)个区间组成,每个区间的形式为\[I(i) = [a(i), b(i)], 1 \leq i \leq n\],其中\(b(1) \leq b(2) ...

    区间数排序方法评述

    这些情形包括:两个区间数不相交,相交且只有一个交点,相交但交点不止一个,以及相交包含。这13种情形又可以根据交点的数量和区间的中点位置关系进一步细分。 在区间数排序方法方面,目前的研究主要分为两大类:一...

    红黑树、区间树

    在查询时,区间树可以快速定位到与目标区间相交的所有元素。区间树的操作包括插入区间、删除区间、更新区间以及查询区间交集。 在给定的“main函数中写的是区间树的测试程序”,这通常意味着文件包含了一个C++或...

    在matlab中连续区间 交集 和 并集

    在MATLAB中,通常使用向量来表示连续区间,例如`A = [a, b, c, d]`,这代表了一个由两个不相交子区间`(a, b)`和`(c, d)`组成的集合`A`。这里的最简表达式意味着区间没有重叠部分,并且已按顺序排列。因此,`[a, b, c...

    判断线段相交及点是否在多边形内

    在计算机图形学和算法设计中,判断线段相交与点是否在多边形内是常见的问题,尤其在碰撞检测、几何渲染等领域有着广泛应用。本文将深入探讨这两个知识点,并结合提供的源代码`is_iner.cpp`和文档`是否相交.doc`进行...

    贪心算法区间包含

    已知 n 个左闭右开区间 [ a , b) ,对其进行 m 次询问,求区间 [ l , r ] 最多可以包含 n 个区间中的多少个区间,并且被包含的所有区间都不相交。 用于贪心算法对区间包含问题的解决

    红黑树与区间树算法实现

    区间树可以快速地找出与给定区间相交的所有区间,时间复杂度通常也是O(log n)。在实验中,`IntervalTree.c`和`IntervalTree.h`实现了区间树的构造、插入、删除和查询功能。 `csdn-红黑树与区间树.doc`文档可能包含...

    结构区间可靠性分析的可能度法

    - 两个区间相交但不包含,说明结构的应力和强度之间存在一定的不确定性。 - 两个区间相交且交点多于一个,则表明结构在某些情况下可能会失效。 通过这些区间关系,可以对结构在不同条件下的可靠性进行评估。 六、...

    java 区间

    当需要快速查找与特定值相交的区间时,这样的数据结构非常有用。 对于“源码”标签,可能意味着我们需要查看Java标准库或其他开源库中对区间的实现。例如,Guava库提供了一个`Range`类,它支持区间操作并提供了丰富...

Global site tag (gtag.js) - Google Analytics