-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathsearch_a_2d_matrix.dart
95 lines (69 loc) · 2.06 KB
/
search_a_2d_matrix.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/*
-* 74. Search a 2D Matrix *-
You are given an m x n integer matrix matrix with the following two properties:
Each row is sorted in non-decreasing order.
The first integer of each row is greater than the last integer of the previous row.
Given an integer target, return true if target is in matrix or false otherwise.
You must write a solution in O(log(m * n)) time complexity.
Example 1:
Input: matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
Output: true
Example 2:
Input: matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13
Output: false
Constraints:
m == matrix.length
n == matrix[i].length
1 <= m, n <= 100
-104 <= matrix[i][j], target <= 104
*/
class A {
bool searchMatrix(List<List<int>> matrix, int target) {
final List<int> innerList =
matrix.expand((innerArray) => innerArray).toList();
return innerList.contains(target);
}
}
class Solution {
int search(List<int> v, int target) {
final int index = lowerBound(v, target);
return index;
}
bool searchMatrix(List<List<int>> matrix, int target) {
final int n = matrix.length;
final int m = matrix[0].length;
if (n == 1) {
final int j = search(matrix[0], target);
if (j == m) return false;
return matrix[0][j] == target;
}
final List<int> col0 = List<int>.generate(n, (i) => matrix[i][0]);
final int i0 = search(col0, target);
if (i0 == n) {
final int j = search(matrix[i0 - 1], target);
if (j == m) return false;
return matrix[i0 - 1][j] == target;
} else if (col0[i0] == target) {
return true;
} else if (i0 == 0) {
return false;
} else {
final int j = search(matrix[i0 - 1], target);
if (j == m) return false;
return matrix[i0 - 1][j] == target;
}
}
int lowerBound(List<int> array, int target) {
int left = 0;
int right = array.length;
while (left < right) {
int mid = left + (right - left) ~/ 2;
if (array[mid] < target) {
left = mid + 1;
} else {
right = mid;
}
}
return left;
}
}