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也能达到同样的效果,而且能节省空间