C語言面試C++二維數(shù)組中的查找示例
更新時間:2021年09月28日 10:43:57 作者:小碼農(nóng)UU
這篇文章主要介紹了C語言面試C++二維數(shù)組中的查找示例,文中給出基本能拿下面試官的操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助
二維數(shù)組中的查找
面試題3:

似題:
我做過這個類似的有楊氏矩陣為背景的,實際上是一樣的
暴力遍歷
二維數(shù)組暴力遍歷的話時間復雜度為O(n2)
雖然暴力但是應付學??荚囘@個就是一把好手
#include<stdio.h>
//const 就是因為二維數(shù)組是定死的
int search(const int arr[4][4], int num,unsigned int* prow,unsigned int* pcol)
{
int i = 0;
//掃描行
for (i = 0; i < *prow; i++)
{
//掃描列
int j = 0;
for (j = 0; j < *pcol; j++)
{
//與所查數(shù)比較判斷,有一樣的就直接返回
if (arr[i][j] == num)
{
*prow = i;//把坐標傳回去
*pcol = j;
return 1;//一次返回,之后就不看了,因為已經(jīng)證明到有這個數(shù)了,沒必要在做無用功了
}
}
}
return 0;
}
int main()
{
int arr[4][4] = { {1,2,8,9},{2,4,9,12},{4,7,10,13},{6,8,11,15} };
int num = 0;
while (1)
{
unsigned int row = sizeof(arr) / sizeof(arr[0]);
unsigned int col = sizeof(arr[0]) / sizeof(arr[0][0]); //把row,col拉進來就是為了每次再來是更新一次
//長寬,因為下面我們就是用row,col變量沒有用其他變量
printf("請輸入你想要找的數(shù):>");
scanf("%d", &num);
if (search(arr, num, &row, &col))//把長寬傳地址過去用指針prow,pcol接收
{
printf("有這個數(shù)\n");
printf("坐標為(%d,%d)\n", row, col);
}
else
{
printf("沒有這個數(shù)\n");
}
}
return 0;
}

動態(tài)基點操作
暴力操作肯定拿不下面試官的心,沒有思想,應該優(yōu)化程序,減小時間復雜度



然后把上面search函數(shù)改改就可以了
時間復雜度也降為O(n)
#include<stdio.h>
//const 就是因為二維數(shù)組是定死的
int search(const int arr[4][4], int num,unsigned int* prow,unsigned int* pcol)
{
int i = 0;
unsigned int x = 0;
unsigned int y = *pcol-1;
while ((x<*prow)&&(y>=0))
{
if (arr[x][y] - num > 0)
{
y--;
}
else if (arr[x][y] - num < 0)
{
x++;
}
else
{
*prow = x;
*pcol = y;
return 1;
}
}
return 0;
}
int main()
{
int arr[4][4] = { {1,2,8,9},{2,4,9,12},{4,7,10,13},{6,8,11,15} };
int num = 0;
while (1)
{
unsigned int row = sizeof(arr) / sizeof(arr[0]);
unsigned int col = sizeof(arr[0]) / sizeof(arr[0][0]); //把row,col拉進來就是為了每次再來是更新一次
//長寬,因為下面我們就是用row,col變量沒有用其他變量
printf("請輸入你想要找的數(shù):>");
scanf("%d", &num);
if (search(arr, num, &row, &col))//把長寬傳地址過去用指針prow,pcol接收
{
printf("有這個數(shù)\n");
printf("坐標為(%d,%d)\n", row, col);
}
else
{
printf("沒有這個數(shù)\n");
}
}
return 0;
}

結(jié)果也是不錯的
以上就是C語言面試C++二維數(shù)組中的查找示例的詳細內(nèi)容,更多關(guān)于C++二維數(shù)組中的查找的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
函數(shù)外初始化與函數(shù)內(nèi)初始化詳細解析
函數(shù)內(nèi)初始化:bool FillStr(char *&szDst, int nSize);第一個參數(shù)中的&一定不能少,這是因為在函數(shù)外部我們只聲明了這個指針,具體這個指針指向內(nèi)存中的哪個地址我們并不知道,所以&是為了說明傳遞的是這個指針的引用,那么在函數(shù)內(nèi)初始化后這個指針的地址也就是外面指針的地址了2013-09-09
c語言函數(shù)棧幀的創(chuàng)建和銷毀過程詳解
我們知道c語言中函數(shù)都是被調(diào)用的,main函數(shù)里面能調(diào)用其他函數(shù),其實main函數(shù)也是被別的函數(shù)調(diào)用的,下面通過本文給大家分享c語言函數(shù)棧幀的創(chuàng)建和銷毀過程,一起看看吧2021-08-08

