亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Java編程數組中最大子矩陣簡便解法實現代碼

2024-07-13 10:17:23
字體:
來源:轉載
供稿:網友

本文研究的主要是Java編程數組中最大子矩陣的相關內容,具體介紹如下。

java,數組,最大子矩陣,java數組矩陣,矩陣轉數組

遇到一個好人,可以改變一生;遇到一本好書,又何嘗不是呢?

最近在翻閱 左程云先生的程序員代碼面試指南–IT名企算法與數據結構題目最優解時就非常的有感悟。建議有這方面愛好的博友,也去觀摩觀摩。

書中講解的基于棧的數組的最大矩陣的算法很經典,但是博主能力有限,沒能徹底的領悟該算法的精髓,但是根據這個思想,博主想出了一種簡易的應對該類問題的算法,現概述如下。

核心思想

先來看一張圖吧,我們就可以大致的理解了。

java,數組,最大子矩陣,java數組矩陣,矩陣轉數組

如圖,每一個輪次都是一次運算,而我們的核心就是針對這每一個輪次的內部的運算。

計算出每一層連續不間斷的最大長度

也就是說,我們是最這個數組進行由下至上的輪次計算,然后針對每一輪就可以計算出本輪次可以得出的連續最大子矩陣的面積。然后只需要比較每一個輪次的最大的那個數據,返回就可以求出該數組最大的連續的子矩陣的面積了。

代碼

好了,有了上面的核心思想的鋪墊,我們就可以著手編寫代碼了。(雖然我也覺得自己并沒有說的很清楚,見諒見諒)。

java;">package stack_and_queue;/** * @author 郭 璞<br> *  根據數組來計算連續的最大的矩形區域的面積 */public class MaxRectangle {	public static void main(String[] args) {		Integer[] arr = { 2, 1, 3, 5, 7, 6, 4 };		Integer maxRectangle = maxRectangleArea(arr);		System.out.println("數組中最大的連續的矩形區域的面積為: " + maxRectangle);	}	/** * @param arr * @return 數組中連續矩形區域的最大面積 */	private static Integer maxRectangleArea(Integer[] arr) {		int[] result = new int[arr.length];		// 對數組進行遍歷式的計算,由底向上不間斷的連續長度		for (int i = 1; i <= arr.length; i++) {			// 當前輪次 中實現對連續長度的累加的臨時取值			int templen = 0;			// 記錄本輪高度下的最大連續長度			int templen_max = 0;			// 內層循環應該是從數組首部開始,而從當先層下標開始會導致前面部分數據的丟失			for (int j = 1; j <= arr.length; j++) {				if (arr[j - 1] >= i) {					templen += 1;					templen_max = templen;				} else {					templen = 0;				}			}			result[i - 1] = i * templen_max;			// System.out.println("第" + i + "層連續不間斷的最大長度為:" + templen_max);		}		// 求得結果集數組中數值最大的那個數,即為所求連續區域中的最大的矩形域的面積		int maxArea = 0;		for (int i = 0; i < result.length; i++) {			maxArea = maxArea > result[i] ? maxArea : result[i];		}		// 將所求得的最大連續矩形域的面積返回		return maxArea;	}}

代碼中的注釋也比較的全面,就不再過多的贅述了。

測試

下面就對數組進行測試。首先以本文開頭圖片上所示的數組來進行測試吧。

Integer[] arr = {2,1,3,5,7,6,4}···

數組中最大的連續的矩形區域的面積為: 16

然后我們修改一下數組中元素的值,來進一步的測試看看結果是否正確。

java,數組,最大子矩陣,java數組矩陣,矩陣轉數組

Integer[] arr = {2,1,3,1,7,6,4}···

數組中最大的連續的矩形區域的面積為: 12

經博主本人親自測試,該算法可以正常的工作。 :)

優化部分

說道優化部分,首先我們可以看出的估計便是最后的那步求結果集數組中的最大值了吧。

確實是的,我們其實可以另外申請一個變量,來記錄到目前為止的輪次的最大的那個子矩陣的面積的。不過 這點優化而言起到的作用不是很大,時間復雜度也沒有什么比較大的改善。

另外一點,我覺的可以比較好的切入點就是對每一個輪次的進行運算的時候添加一個判斷,來決定當前輪次之前是否往下循環。如果數組中的元素的波動比較大的話,優化的程度還是很不錯的。

總結

這個小算法比較精巧,唯一比較缺憾的地方就是時間復雜度稍微的有點大了。如果讀者在尋求一種時間復雜度比較小的算法的話,請繞道咯。

如果只是想尋求一個結果,還是不錯的。至少比暴力方式的計算效率高多了。

以上就是本文關于Java編程數組中最大子矩陣簡便解法實現代碼的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
一区二区三区国产在线观看| 宅男66日本亚洲欧美视频| 最近2019年中文视频免费在线观看| 97视频色精品| 成人av.网址在线网站| 亚洲免费视频在线观看| 奇米四色中文综合久久| 欧美国产视频一区二区| 亚洲的天堂在线中文字幕| 国产精品www网站| 狠狠躁天天躁日日躁欧美| 亚洲欧美一区二区精品久久久| 欧美男插女视频| 在线视频一区二区| 欧美激情在线观看视频| 精品少妇一区二区30p| 欧美精品激情blacked18| 日韩在线播放av| 亚洲专区在线视频| 欧美精品在线网站| 在线播放亚洲激情| 久久精品91久久久久久再现| 中文字幕自拍vr一区二区三区| 久久精品中文字幕| 日本成熟性欧美| 日韩精品免费一线在线观看| 青草青草久热精品视频在线网站| 欧美老肥婆性猛交视频| 青青草国产精品一区二区| 亚洲综合小说区| 欧美大片在线看免费观看| 98午夜经典影视| 国产美女91呻吟求| 欧美亚洲国产成人精品| 欧美日韩国产影院| 欧美做受高潮电影o| 国产精品第一页在线| 国产成人精品亚洲精品| 久久久在线视频| 欧美日韩在线影院| 久久夜色精品亚洲噜噜国产mv| 96精品视频在线| 国产一区二区日韩精品欧美精品| 91免费看片在线| 亚洲欧美色图片| 欧美性极品xxxx娇小| 亚洲九九九在线观看| 日韩国产精品亚洲а∨天堂免| 美女福利精品视频| 亚洲精品自拍第一页| 在线一区二区日韩| 亚洲一区二区三| 亚洲精品视频在线观看视频| 日本欧美精品在线| 国产在线观看一区二区三区| 日韩中文字幕在线免费观看| 日韩av免费网站| 久久久91精品国产一区不卡| 97国产精品视频| 日本免费一区二区三区视频观看| 亚洲国产成人久久综合一区| 亚洲精品成人久久电影| 欧美日韩国产91| 亚洲国产精久久久久久久| 亚洲免费一在线| 91美女片黄在线观| 亚洲欧洲日产国产网站| 亚洲天堂久久av| 91精品91久久久久久| 国产欧美日韩高清| 色狠狠av一区二区三区香蕉蜜桃| 91精品国产高清久久久久久| 国产一区二区三区在线播放免费观看| 亚洲3p在线观看| 欧美性猛交xxxx乱大交| 欧美成人精品不卡视频在线观看| 亚洲欧洲在线播放| 国产精品第1页| 亚洲性夜色噜噜噜7777| 26uuu另类亚洲欧美日本一| 91麻豆国产语对白在线观看| 欧美日韩成人在线视频| 亚洲欧美日韩精品| 日韩电影中文字幕av| 欧美成人精品在线视频| 日本高清+成人网在线观看| 日韩精品高清在线| 日韩美女av在线免费观看| 久久久久久有精品国产| 亚洲成av人片在线观看香蕉| 亚州av一区二区| 亚州精品天堂中文字幕| 亚洲成人久久电影| 热久久99这里有精品| 九九精品视频在线| 日韩av手机在线看| 亚洲第一色中文字幕| 日本亚洲欧洲色| 欧美日韩亚洲成人| 91久久在线播放| 久久视频在线看| 日韩成人小视频| 国产精品草莓在线免费观看| 久久久www成人免费精品| 91久久精品久久国产性色也91| …久久精品99久久香蕉国产| 2019中文在线观看| 国产精品欧美在线| 亚洲人成在线一二| 国产精品欧美一区二区| 在线看日韩欧美| 国产亚洲欧洲高清一区| 日本一区二区三区四区视频| 亚洲精品一区久久久久久| 国产精品美女免费视频| 夜夜躁日日躁狠狠久久88av| 亚洲精品v天堂中文字幕| 性欧美xxxx视频在线观看| 欧美日韩性视频| 永久免费看mv网站入口亚洲| 永久免费看mv网站入口亚洲| 久久综合免费视频影院| 日韩高清不卡av| 国产精品稀缺呦系列在线| 久久精品国产99国产精品澳门| 久久久精品影院| 亚洲国产精品悠悠久久琪琪| 精品亚洲精品福利线在观看| 欧美成人三级视频网站| 国产成人精品免费视频| 高清欧美电影在线| 国产精品亚洲视频在线观看| 欧美大片在线看| 日韩高清电影免费观看完整| 91免费综合在线| 欧美在线www| 日韩一区视频在线| 久久精品一偷一偷国产| 最近的2019中文字幕免费一页| 欧美日本啪啪无遮挡网站| 国产精品亚洲视频在线观看| 色偷偷av亚洲男人的天堂| 欧美麻豆久久久久久中文| 91视频国产一区| 91精品久久久久久久久久入口| 日韩精品极品视频免费观看| 国产精品美女999| 亚洲三级 欧美三级| 欧美国产第二页| 日本精品久久久| 日韩精品在线免费观看视频| 久久久免费电影| 亚洲精品网址在线观看| 日韩成人在线视频观看| 精品视频偷偷看在线观看| 亚洲精品www久久久久久广东| 国产91精品黑色丝袜高跟鞋| 久久精品91久久久久久再现| 色综久久综合桃花网| 奇米成人av国产一区二区三区| 国产裸体写真av一区二区| 亚洲成**性毛茸茸| 欧美性猛交xxxx免费看漫画| 久久久久久国产精品久久|