有一个数字矩阵,矩阵的每行从左到右时递增的,矩阵从上到下时递减的,请编写程序在这样的矩阵中查找某个数是否存在。
时间复杂度小于O(N)
//1 2 3 1 2 3
//4 5 6 2 3 4
//7 8 9 4 5 6
#include<stdio.h>
void Findnum(int arr[][3], int k, int row, int col)
{
int x = 0;
int y = col - 1;
while (x < row && y >= 0)
{
if (arr[x][y] > k)
{
y--;
}
else if (arr[x][y] < k)
{
x++;
}
else
{
printf("arr[%d][%d]", x, y);
break;
}
}
}
int main()
{
int i = 0;
scanf_s("%d", &i);
int arr[3][3] = { {1,2,3},{4,5,6},{7,8,9} };
/*int j = 0;
for (j = 0; j < 3; j++)
{
if (arr[j][2] >= i)
{
int k = 2;
while (arr[j][k] != i && j < 3)
{
k--;
}
printf("arr[%d][%d]", j, k);
break;
}
}*/
Findnum(arr, i, 3, 3);
}
|