LeetCode - Maximal Rectangle

来源:http://www.cnblogs.com/shuaiwhu/archive/2016/01/03/5096766.html
-Advertisement-
Play Games

題目:Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and return its area.思路:類似於上一篇文章中的方法一,對每列的左右拓展極限進行記...


題目:

Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and return its area.

思路:

類似於上一篇文章中的方法一,對每列的左右拓展極限進行記錄,同時保存當前列的高度。

package area;

public class MaximalRectangle {

    public int maximalRectangle(char[][] matrix) {
        int m;
        int n;
        if (matrix == null || (m = matrix.length) == 0 || (n = matrix[0].length) == 0) return 0;
// Height of this column
int[] H = new int[n]; int[] L = new int[n]; int[] R = new int[n]; for (int i = 0; i < n; ++i) { H[i] = 0; L[i] = 0; R[i] = n; } int max = 0; for (int i = 0; i < m; ++i) { int left = 0; int right = n; for (int j = 0; j < n; ++j) { if (matrix[i][j] == '1') { ++H[j]; L[j] = Math.max(L[j], left); } else { left = j + 1; H[j] = 0; L[j] = 0; R[j] = n; } } for (int j = n - 1; j >= 0; --j) { if (matrix[i][j] == '1') { R[j] = Math.min(R[j], right); max = Math.max((R[j] - L[j]) * H[j], max); } else { right = j; } } } return max; } public static void main(String[] args) { // TODO Auto-generated method stub char[][] matrix = { { '0', '1', '1', '0', '1' }, { '1', '1', '0', '1', '0' }, { '0', '1', '1', '1', '0' }, { '1', '1', '1', '1', '0' }, { '1', '1', '1', '1', '1' }, { '0', '0', '0', '0', '0' } }; MaximalRectangle m = new MaximalRectangle(); System.out.println(m.maximalRectangle(matrix)); } }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 2016-01-03 Swith(整數選擇因數):必須是int或char這樣的整數值。 Java中不包含goto語句,但是可以通過標識符實現類似的控制。
  • Django ORM 中的批量操作 在Hibenate中,通過批量提交SQL操作,部分地實現了資料庫的批量操作。但在Django的ORM中的批量操作卻要完美得多,真是一個驚喜。 數據模型定義 首先,定義一個實例使用的django資料庫模型Product,只是象徵性地定義了兩個欄位name...
  • 今天終於開始進行OC的學習了一.首先講了NSLogNSLog是oc裡面的輸出語句,其用法和printf差不多,但是還是有差別的1,NSLog是自動換行的,不用像printf那樣還需要加'\n';2,NSLog在引號面前需要添加@符號,例如: NSLog(@"Hello World"); ...
  • 15.1、原理步驟註冊:註冊時,將用戶密碼加密放入資料庫登錄:登錄時,將用戶密碼採用上述相同的演算法加密,之後再與資料庫中的信息進行比對,若相同,則登錄15.2、實現(這裡採用了SHA256演算法,其他摘要演算法MD5/SHA1/MAC類似)註意:這裡的程式是在我之前寫的一個maven+spring+sp...
  • 剛開始學習python,之前完全沒有接觸,在這裡寫下自己學習python的過程和心得。 首先,安裝python,打開官網:http://python.org.點擊Download.我選擇了3.5.1版本進行安裝。 接下來,按照教程開始學習: 於是開始了經典的第一個程式,在互動式解釋器里輸入...
  • 運行時數據區域程式計數器(Program Counter Register):可看作是當前程式所執行的位元組碼的行號指示器。在虛擬機的概念模型里(不同虛擬機可能有不同的實現方法),位元組碼解釋器就是通過改變程式計數器的值來取下一條位元組碼指令,分支、迴圈、跳轉、異常處理、線程恢復等基礎功能都依賴於這個計數...
  • 一、ssmm簡介ssmm是當下企業最常用的開發框架架構maven:管理項目jar包,構建項目spring:IOC容器,事務管理springmvc:mvc框架myBatis:持久層框架velocity:前端視圖模板(相較於jsp,速度非常快,而且不需要占據jvm的永久代記憶體)上述這些框架再加上版本控制...
  • 1.直接通過github搜索tomcat,正好找到一位有部分翻譯內容的版本,直接fork並下載git clone https://github.com/codefollower/Tomcat-Research.git2.轉換成eclipse項目工程,如果沒有安裝maven,可以先配置maven環境變...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...