欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java編程數(shù)組中最大子矩陣簡(jiǎn)便解法實(shí)現(xiàn)代碼

 更新時(shí)間:2018年01月26日 16:33:53   作者:Marksinoberg  
這篇文章主要介紹了Java編程數(shù)組中最大子矩陣簡(jiǎn)便解法實(shí)現(xiàn)代碼,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下

本文研究的主要是Java編程數(shù)組中最大子矩陣的相關(guān)內(nèi)容,具體介紹如下。

遇到一個(gè)好人,可以改變一生;遇到一本好書(shū),又何嘗不是呢?

最近在翻閱 左程云先生的程序員代碼面試指南–IT名企算法與數(shù)據(jù)結(jié)構(gòu)題目最優(yōu)解時(shí)就非常的有感悟。建議有這方面愛(ài)好的博友,也去觀摩觀摩。

書(shū)中講解的基于棧的數(shù)組的最大矩陣的算法很經(jīng)典,但是博主能力有限,沒(méi)能徹底的領(lǐng)悟該算法的精髓,但是根據(jù)這個(gè)思想,博主想出了一種簡(jiǎn)易的應(yīng)對(duì)該類問(wèn)題的算法,現(xiàn)概述如下。

核心思想

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

如圖,每一個(gè)輪次都是一次運(yùn)算,而我們的核心就是針對(duì)這每一個(gè)輪次的內(nèi)部的運(yùn)算。

計(jì)算出每一層連續(xù)不間斷的最大長(zhǎng)度

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

代碼

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

package stack_and_queue;
/**
 * @author 郭 璞<br>
 *  根據(jù)數(shù)組來(lái)計(jì)算連續(xù)的最大的矩形區(qū)域的面積
 */
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("數(shù)組中最大的連續(xù)的矩形區(qū)域的面積為: " + maxRectangle);
	}
	/**
 * @param arr
 * @return 數(shù)組中連續(xù)矩形區(qū)域的最大面積
 */
	private static Integer maxRectangleArea(Integer[] arr) {
		int[] result = new int[arr.length];
		// 對(duì)數(shù)組進(jìn)行遍歷式的計(jì)算,由底向上不間斷的連續(xù)長(zhǎng)度
		for (int i = 1; i <= arr.length; i++) {
			// 當(dāng)前輪次 中實(shí)現(xiàn)對(duì)連續(xù)長(zhǎng)度的累加的臨時(shí)取值
			int templen = 0;
			// 記錄本輪高度下的最大連續(xù)長(zhǎng)度
			int templen_max = 0;
			// 內(nèi)層循環(huán)應(yīng)該是從數(shù)組首部開(kāi)始,而從當(dāng)先層下標(biāo)開(kāi)始會(huì)導(dǎo)致前面部分?jǐn)?shù)據(jù)的丟失
			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 + "層連續(xù)不間斷的最大長(zhǎng)度為:" + templen_max);
		}
		// 求得結(jié)果集數(shù)組中數(shù)值最大的那個(gè)數(shù),即為所求連續(xù)區(qū)域中的最大的矩形域的面積
		int maxArea = 0;
		for (int i = 0; i < result.length; i++) {
			maxArea = maxArea > result[i] ? maxArea : result[i];
		}
		// 將所求得的最大連續(xù)矩形域的面積返回
		return maxArea;
	}
}

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

測(cè)試

下面就對(duì)數(shù)組進(jìn)行測(cè)試。首先以本文開(kāi)頭圖片上所示的數(shù)組來(lái)進(jìn)行測(cè)試吧。

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

數(shù)組中最大的連續(xù)的矩形區(qū)域的面積為: 16

然后我們修改一下數(shù)組中元素的值,來(lái)進(jìn)一步的測(cè)試看看結(jié)果是否正確。

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

數(shù)組中最大的連續(xù)的矩形區(qū)域的面積為: 12

經(jīng)博主本人親自測(cè)試,該算法可以正常的工作。 :)

優(yōu)化部分

說(shuō)道優(yōu)化部分,首先我們可以看出的估計(jì)便是最后的那步求結(jié)果集數(shù)組中的最大值了吧。

確實(shí)是的,我們其實(shí)可以另外申請(qǐng)一個(gè)變量,來(lái)記錄到目前為止的輪次的最大的那個(gè)子矩陣的面積的。不過(guò) 這點(diǎn)優(yōu)化而言起到的作用不是很大,時(shí)間復(fù)雜度也沒(méi)有什么比較大的改善。

另外一點(diǎn),我覺(jué)的可以比較好的切入點(diǎn)就是對(duì)每一個(gè)輪次的進(jìn)行運(yùn)算的時(shí)候添加一個(gè)判斷,來(lái)決定當(dāng)前輪次之前是否往下循環(huán)。如果數(shù)組中的元素的波動(dòng)比較大的話,優(yōu)化的程度還是很不錯(cuò)的。

總結(jié)

這個(gè)小算法比較精巧,唯一比較缺憾的地方就是時(shí)間復(fù)雜度稍微的有點(diǎn)大了。如果讀者在尋求一種時(shí)間復(fù)雜度比較小的算法的話,請(qǐng)繞道咯。

如果只是想尋求一個(gè)結(jié)果,還是不錯(cuò)的。至少比暴力方式的計(jì)算效率高多了。

以上就是本文關(guān)于Java編程數(shù)組中最大子矩陣簡(jiǎn)便解法實(shí)現(xiàn)代碼的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!

相關(guān)文章

  • MyBatis-Plus?Page?分頁(yè)不生效的問(wèn)題解決

    MyBatis-Plus?Page?分頁(yè)不生效的問(wèn)題解決

    分頁(yè)是常見(jiàn)的一種功能,本文主要介紹了MyBatis-Plus?Page分頁(yè)不生效的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-07-07
  • RecyclerChart的KLine的繪制

    RecyclerChart的KLine的繪制

    這篇文章主要為大家介紹了RecyclerChart的KLine的繪制示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • java 中斷線程的幾種方式 interrupt()詳解

    java 中斷線程的幾種方式 interrupt()詳解

    中斷(Interrupt)一個(gè)線程意味著在該線程完成任務(wù)之前停止其正在進(jìn)行的一切,有效地中止其當(dāng)前的操作。這篇文章主要介紹了java 中斷線程的幾種方式 interrupt(),需要的朋友可以參考下
    2021-11-11
  • java構(gòu)造函數(shù)的三種類型總結(jié)

    java構(gòu)造函數(shù)的三種類型總結(jié)

    在本篇文章里小編給大家整理了一篇關(guān)于java構(gòu)造函數(shù)的三種類型總結(jié)內(nèi)容,有需要的朋友們可以學(xué)習(xí)參考下。
    2021-01-01
  • java核心編程之文件過(guò)濾類FileFilter和FilenameFilter

    java核心編程之文件過(guò)濾類FileFilter和FilenameFilter

    這篇文章主要為大家詳細(xì)介紹了java文件過(guò)濾類FileFilter和FilenameFilter,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • MyBatis框架簡(jiǎn)介

    MyBatis框架簡(jiǎn)介

    本文主要介紹了MyBatis框架的基礎(chǔ)知識(shí)。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧
    2017-03-03
  • 實(shí)現(xiàn) Java 本地緩存的方法解析

    實(shí)現(xiàn) Java 本地緩存的方法解析

    這篇文章主要介紹了實(shí)現(xiàn) Java 本地緩存的方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • Java Web項(xiàng)目創(chuàng)建并實(shí)現(xiàn)前后端交互

    Java Web項(xiàng)目創(chuàng)建并實(shí)現(xiàn)前后端交互

    本文主要介紹了Java Web項(xiàng)目創(chuàng)建并實(shí)現(xiàn)前后端交互,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Java斗地主發(fā)牌課程設(shè)計(jì)

    Java斗地主發(fā)牌課程設(shè)計(jì)

    這篇文章主要為大家詳細(xì)介紹了Java斗地主發(fā)牌課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • Java中的equsals和==

    Java中的equsals和==

    這篇文章主要介紹了Java中的equsals和==的相關(guān)內(nèi)容,感興趣的朋朋友可以參考下文
    2021-08-08

最新評(píng)論