1893. 检查是否区域内所有整数都被覆盖

1893. 检查是否区域内所有整数都被覆盖

贴个题目:

题目

贴个示例:

示例

解题思路:

第一种:暴力AC法+哈希表

使用哈希表对二维数组中的范围进行记录,然后从left遍历到right,如果都有记录,就返回true,一旦一个没有记录那就返回false

贴个代码:
bool isCovered(int** ranges, int rangesSize, int* rangesColSize, int left, int right){
    int arr[52];//题目有给定长度
    memset(arr,0,sizeof(arr));//哈希数组初始化为0
    for(int i=0;i<rangesSize;i++)
    {
        for(int j=ranges[i][0];j<=ranges[i][1];j++)
        //将这个区间内的元素全部记录下来
        {
            arr[j]++;
        }
    }
    while(left<=right)
    {
        if(arr[left]==0) return false;//一旦出现没有记录的情况就返回false
        else left++;
    }
    return true;//经受了上面遍历的考验,因此返回true
}
第一种方法的性能分析:
时间分析:

题目中规定了二维数组列数为2,行数为n,下面使用了left<=right的循环
因此时间复杂度是:O(2*n+right-left)=O(n)

空间分析:

题目新建了长度为52的哈希数组,为常数长度,因此可以是:O(1)?,感觉有点问题,希望有大佬指正

第二种:差分数组

感觉思想都差不多,这里就贴上力扣的官方的题解:检查是否区域内所有整数都被覆盖

总结:

忽然想到,哈希数组如果用的是bool也能达到同样的效果,而且能节省空间

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值