LeetCode //C - 757. Set Intersection Size At Least Two

757. Set Intersection Size At Least Two

You are given a 2D integer array intervals where i n t e r v a l s [ i ] = [ s t a r t i , e n d i ] intervals[i] = [start_i, end_i] intervals[i]=[starti,endi] represents all the integers from s t a r t i start_i starti to e n d i end_i endi inclusively.

A containing set is an array nums where each interval from intervals has at least two integers in nums.

  • For example, if intervals = [[1,3], [3,7], [8,9]], then [1,2,4,7,8,9] and [2,3,4,8,9] are containing sets.

Return the minimum possible size of a containing set.

Example 1:

Input: intervals = [[1,3],[3,7],[8,9]]
Output: 5
Explanation: let nums = [2, 3, 4, 8, 9].

It can be shown that there cannot be any containing array of size 4.

Example 2:

Input: intervals = [[1,3],[1,4],[2,5],[3,5]]
Output: 3
Explanation: let nums = [2, 3, 4].

It can be shown that there cannot be any containing array of size 2.

Example 3:

Input: intervals = [[1,2],[2,3],[2,4],[4,5]]
Output: 5
Explanation: let nums = [1, 2, 3, 4, 5].

It can be shown that there cannot be any containing array of size 4.

Constraints:
  • 1 <= intervals.length <= 3000
  • intervals[i].length == 2
  • 0 < = s t a r t i < e n d i < = 10 8 0 <= start_i < end_i <= 10^8 0<=starti<endi<=108

From: LeetCode

Link: 757. Set Intersection Size At Least Two


Solution:

Ideas:
  • Sort intervals by end point (ascending), then by start point (descending) when end points are equal

  • Track state using two variables: point1 and point2 (last two points added to our set)

  • Process each interval and check how many of our current points it contains:

    • Contains 0 points (start > point2): Add 2 points at positions end-1 and end
    • Contains 1 point (start > point1): Add 1 point at position end
    • Contains 2+ points: Add 0 points
Code:
c 复制代码
// Comparator function to sort intervals by end point
// If end points are equal, sort by start point in descending order
int compare(const void* a, const void* b) {
    int* intervalA = *(int**)a;
    int* intervalB = *(int**)b;
    if (intervalA[1] != intervalB[1]) {
        return intervalA[1] - intervalB[1];  // Sort by end point ascending
    }
    return intervalB[0] - intervalA[0];  // If end points equal, sort by start point descending
}

int intersectionSizeTwo(int** intervals, int intervalsSize, int* intervalsColSize) {
    if (intervalsSize == 0) return 0;
    
    // Sort intervals by end point
    qsort(intervals, intervalsSize, sizeof(int*), compare);
    
    int count = 0;
    int point1 = INT_MIN;  // Second to last point added
    int point2 = INT_MIN;  // Last point added
    
    for (int i = 0; i < intervalsSize; i++) {
        int start = intervals[i][0];
        int end = intervals[i][1];
        
        if (start > point2) {
            // Current interval doesn't contain any of our points
            // Add the two rightmost points of this interval
            count += 2;
            point1 = end - 1;
            point2 = end;
        } else if (start > point1) {
            // Current interval contains only point2
            // Add one more point (the rightmost one)
            count += 1;
            point1 = point2;
            point2 = end;
        }
        // If start <= point1, then the interval contains both point1 and point2
        // No need to add any points
    }
    
    return count;
}
相关推荐
2401_876221341 分钟前
因数个数、因数和、因数积
c++·算法
云里雾里!11 分钟前
LeetCode 744. 寻找比目标字母大的最小字母 | 从低效到最优的二分解法优化
算法·leetcode
一条大祥脚25 分钟前
26.1.3 快速幂+容斥 树上dp+快速幂 带前缀和的快速幂 正序转倒序 子序列自动机 线段树维护滑窗
数据结构·算法
二狗哈30 分钟前
czsc入门5: Tick RawBar(原始k线) NewBar (新K线)
算法·czsc
Tisfy35 分钟前
LeetCode 0865.具有所有最深节点的最小子树:深度优先搜索(一次DFS + Python5行)
算法·leetcode·深度优先·dfs·题解
Q741_14740 分钟前
C++ 队列 宽度优先搜索 BFS 力扣 429. N 叉树的层序遍历 C++ 每日一题
c++·算法·leetcode·bfs·宽度优先
Yzzz-F41 分钟前
P4145 上帝造题的七分钟 2 / 花神游历各国[线段树 区间开方(剪枝) + 区间求和]
算法·机器学习·剪枝
Zzz不能停43 分钟前
堆排序算法及大小堆区别
数据结构·算法
zd8451015001 小时前
stm32f407 电机多轴联动算法
stm32·单片机·算法
代码游侠1 小时前
应用——Linux FrameBuffer图形显示与多线程消息系统项目
linux·运维·服务器·开发语言·前端·算法