代码随想录day36| 435. 无重叠区间 、 763.划分字母区间 、56. 合并区间

435. 无重叠区间 - 力扣(LeetCode)

这道题其实和用最小数量箭引爆气球一样,代码差不多,都是求重叠区间的量

int cmp(const void *a,const void *b)
{
    return ((*((int**)a))[0] > (*((int**)b))[0]);
} 

int eraseOverlapIntervals(int** intervals, int intervalsSize, int* intervalsColSize) {
    if(intervalsSize == 0)
        return 0;
    qsort( intervals, intervalsSize, sizeof( intervals[0]),cmp);
    
    int result = 0;
    int i = 1;
    for(i = 1; i < intervalsSize; i++) {
    
        if(intervals[i][0] >= intervals[i-1][1])
            continue;
        else
           result++;
            intervals[i][1] = intervals[i][1] > intervals[i-1][1] ? intervals[i-1][1] : intervals[i][1];
    }

    return result;
}

763. 划分字母区间

局部最优:就时找这个区间字母中的最远位置,

如何找到这个最远的位置?

——可以用哈希表来记录

/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* partitionLabels(char* s, int* returnSize) {
   int hash[27] ={0};
   for(int i = 0; i < strlen(s); s++){
        hash[s[i] - 'a'] = i;
   } 
   int* ans = (int*)malloc(sizeof(int) * 500);
   *returnSize = 0;
   int start = 0, end = 0;
   for(int j = 0; j < strlen(s); j++){
       end = fmax(end, hash[s[i] - 'a']);
       if (i == end) {
            partition[(*returnSize)++] = end - start + 1;
            start = end + 1;
    return partition;

}

错误:没有正确的认识到这个hash这记录的是位置,不是距离,要用 end - start + 1;表示

56. 合并区间

重叠区间其实代码都是相类似的,判断条件都大体不差,有区别的是要进行什么样的操作

/**
 * Return an array of arrays of size *returnSize.
 * The sizes of the arrays are returned as *returnColumnSizes array.
 * Note: Both returned array and *columnSizes array must be malloced, assume
 * caller calls free().
 */
int cmp(const void* a, const void* b) {
    return ((*((int**)a))[0] > (*((int**)b))[0]);
}

// 合并区间函数
int** merge(int** intervals, int intervalsSize, int* intervalsColSize, int* returnSize, int** returnColumnSizes) {
    int** result = NULL;
    *returnSize = 0;
    *returnColumnSizes = NULL;

    if (intervalsSize == 0) {
        return result;
    }


    result = (int**)malloc(intervalsSize * sizeof(int*));
    *returnColumnSizes = (int*)malloc(intervalsSize * sizeof(int));

    qsort(intervals, intervalsSize, sizeof(intervals[0]), cmp);

    result[*returnSize] = (int*)malloc(2 * sizeof(int));
    result[*returnSize] = intervals[0];
    (*returnColumnSizes)[*returnSize] = 2;
    (*returnSize)++;


    for (int i = 1; i < intervalsSize; i++) { 

        if (result[*returnSize - 1][1] >=  intervals[i][0]) {
        
            result[*returnSize - 1][1] =
                (result[*returnSize - 1][1] > intervals[i][1]) ? result[*returnSize - 1][1] : intervals[i][1];
        } else {
        
            result[*returnSize] = (int*)malloc(2 * sizeof(int));
            result[*returnSize] =  intervals[i];
            (*returnColumnSizes)[*returnSize] = 2;
            (*returnSize)++;
        }
    }

    return result;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值