하나의 m x n 행렬에서 값을 검색하는 효율적인 알고리즘을 작성했다고 가정합니다. 이 행렬에는 다음과 같은 몇 가지 속성이 있습니다. -
- 각 행은 왼쪽에서 오른쪽으로 정렬됩니다.
- 각 행의 첫 번째 숫자는 이전 행의 마지막 정수보다 큽니다.
따라서 행렬이 다음과 같은 경우 -
| 1 | 3 | 5 | 7 |
| 10 | 11 | 16 | 20 |
| 23 | 30 | 34 | 50 |
| 53 | 62 | 78 | 98 |
그리고 목표 값이 16이면 출력은 True가 됩니다.
단계를 살펴보겠습니다 -
- n :=행 수, n이 0이면 false 반환, m :=열 수, m =0이면 false 반환
- 낮음 :=0 및 높음 :=n – 1
- 낮은 동안 <높음
- 중간 :=낮음 + (높음 – 낮음 + 1)/2
- mat[mid, 0] <=target이면 low :=mid, 그렇지 않으면 high :=mid – 1
- rlow :=0 및 rhigh :=m – 1 및 ans :=0
- rlow <=rhigh
- 인 동안
- 중간 :=rlow + (rhigh - rlow)/2
- mat[low, mid] =target이면 ans :=1이고 루프를 끊습니다.
- 그렇지 않으면 matrix[low, mid]
- else rhigh :=중간 – 1
- 반환
이해를 돕기 위해 다음 구현을 살펴보겠습니다. −
예시
#include <bits/stdc++.h>
using namespace std;
typedef long long int lli;
class Solution {
public:
bool searchMatrix(vector<vector<int>>& matrix, int target) {
lli n,m;
n = matrix.size();
if(!n)return false;
m = matrix[0].size();
if(!m)return false;
lli low = 0, high = n-1;
while(low<high){
lli mid = low + ( high - low +1)/2;
if(matrix[mid][0]<=target)low = mid;
else high = mid -1;
}
lli rlow = 0, rhigh = m-1;
lli ans = 0;
while(rlow<=rhigh){
lli mid = rlow+(rhigh - rlow)/2;
if(matrix[low][mid] == target){
ans =1;
break;
}else if(matrix[low][mid]<target)rlow=mid+1;
else rhigh= mid-1;
}
return ans;
}
};
main(){
Solution ob;
vector<vector<int>> v = {{1,3,5,7},{10,11,16,20},{23,30,34,50},{53,62,78,98}};
cout << ob.searchMatrix(v, 16);
} 입력
[[1,3,5,7],[10,11,16,20],[23,30,34,50],[53,62,78,98]] 16
출력
1