C語言楊氏矩陣中查找元素的示例代碼
題目名稱:
楊氏矩陣
題目內(nèi)容:
有一個數(shù)字矩陣,矩陣的每行從左到右是遞增的,矩陣從下到上遞增的(楊氏矩陣的定義),請編寫程序在這樣的矩陣中查找某個數(shù)字是否存在。
形如這樣的矩陣就是楊氏矩陣(本質(zhì)上是一個二維數(shù)組)
要求:
時間復(fù)雜度小于O(N)
解題思路:
因為題目要求時間復(fù)雜度小于O(N),所以我們不能用暴力枚舉遍歷去解決這道題。
如何去簡化時間復(fù)雜度呢?
我們首先要知道具體簡化的點(diǎn)在哪里,O(N)是因為我們遍歷一個一個去排除,最差的情況下,我們需要排除n次,因為遍歷一次,排除1個。那我們就有這樣的簡化思想,遍歷一次,可以排除多個元素,這樣時間復(fù)雜度肯定小于O(N)。
帶著這樣的思路去想,我們發(fā)現(xiàn)最右上角的元素很特殊。
因為它是一行中最大的元素,也是一列中最小的元素。
如果比它小,直接排除列。
如果比它大,直接排除行。
并且這樣的方法可以一直循環(huán)下去,直到遍歷完整個數(shù)組
這也就相當(dāng)于我們遍歷了一個元素,可以排除一行/一列的元素,大大減少了時間復(fù)雜度,滿足題目要求。
TIP:如何自定義函數(shù)返回兩個值?
我們知道函數(shù)的返回值只能返回一個值,如果題目要求我們返回兩個甚至更多的值怎么辦呢?
這個時候我們就可以利用函數(shù)的參數(shù),我們傳參,傳我們需要返回參數(shù)的地址過去,這樣在自定義函數(shù)中我們就可以返回我們想要的參數(shù)!
源碼:
int young_search(int arr[3][3], int row, int col, int k, int* x, int* y) { int ret = 0; while (ret < row && col >= 0) { if (arr[ret][col - 1] == k) { *x = ret + 1; *y = col; return 1; } else if (arr[ret][col - 1] > k) { col--; }
到此這篇關(guān)于C語言楊氏矩陣中尋找元素的示例代碼的文章就介紹到這了,更多相關(guān)C語言楊氏矩陣尋找元素內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Qt?自定義屬性Q_PROPERTY不顯示float類型的解決
這篇文章主要介紹了Qt?自定義屬性Q_PROPERTY不顯示float類型的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11C語言中strcpy和strcat的使用和模擬實現(xiàn)
strcpy()?函數(shù)是?C語言中一個非常重要的字符串處理函數(shù),其功能是將一個字符串復(fù)制到另一個字符串中,strcat函數(shù)可以將一個字符串拼接到另一個字符串的末尾,本文給大家介紹了C語言中strcpy和strcat的使用和模擬實現(xiàn),需要的朋友可以參考下2024-03-03關(guān)于C++內(nèi)存中字節(jié)對齊問題的詳細(xì)介紹
本篇文章是對C++內(nèi)存中字節(jié)對齊的問題進(jìn)行了詳細(xì)的分析與總結(jié)。需要的朋友參考下2013-05-05C++中String類的常用接口函數(shù)總結(jié)
這篇文章主要介紹了C++中Stirng類的常用接口函數(shù),文中有詳細(xì)的代碼示例供大家參考,對我們學(xué)習(xí)C++有一定的幫助,感興趣的同學(xué)可以跟著小編一起來學(xué)習(xí)2023-06-06C語言數(shù)據(jù)結(jié)構(gòu)之堆排序的優(yōu)化算法
堆排序Heap?Sort就是利用堆進(jìn)行排序的方法,下面這篇文章主要給大家介紹了關(guān)于C語言數(shù)據(jù)結(jié)構(gòu)之堆排序的優(yōu)化算法的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04