1159 最大全0子矩陣

来源:http://www.cnblogs.com/lutongxi/archive/2016/04/09/5371095.html
-Advertisement-
Play Games

/*f(i,j)表示以(i,j)為右下角的最大全0子矩陣的邊長若a[i][j]==1,f(i,j)=0否則:f(i,j)=min{ f(i-1,j),f(i,j-1),f(i-1,j-1) }+1 這樣求得的是最大全0正方形子矩陣要求長方形矩陣,上述思路行不通假設以(i,j)為右下角的最大矩陣=12 ...


/*
f(i,j)表示以(i,j)為右下角的最大全0子矩陣的邊長
若a[i][j]==1,f(i,j)=0
否則:f(i,j)=min{ f(i-1,j),f(i,j-1),f(i-1,j-1) }+1
這樣求得的是最大全0正方形子矩陣
要求長方形矩陣,上述思路行不通
假設以(i,j)為右下角的最大矩陣=12
它可能是3*4、4*3、2*6、6*2、1*12、12*1
按上述思路進行狀態轉移的話,取得最優值的方案不唯一時,
所有的方案需要都記下,用於後續的狀態轉移。

在長方形全0子矩陣中,考察某個位置(i,j)
在第i行中,包含(i,j)位置的全0區間長度>=長方形的寬
若第i行是子矩陣的最後一行,由(i,j)位置向上,連續0的個數>=長方形的高
設[l(i,j)..r(i,j)]是第i行上包含(i,j)的全0子區間
第i1行到第i2行且包含(i2,j)的子矩陣需滿足的條件:
(i1..i2,j)均為0,i2-i1+1=矩陣的高
(i,j)對應的區間[l(i,j)..r(i,j)]>=矩陣的寬
孤立地計算l(i,j)、r(i,j),再枚舉i1,i2,j,時間複雜度O(n^3)
l(i,j)與l(i,j-1),r(i,j)與r(i,j+1)之間有關係;
定義h(i,j)表示位置(i,j)向上連續0的個數,h(i,j)與h(i-1,j)之間有關係;
矩形的寬取決於[i1..i2]行中第j列上[l(i,j)..r(i,j)]的最小值
定義l(i,j),r(i,j)分別表示截止到第i行,之前的h(i,j)行中,全0元素的左右區間,
那麼子矩陣的大小=(r(i,j)-l(i,j)+1)*h(i,j)
h(i,j)的遞推關係
if(a[i][j]==0) h(i,j)=h(i,j)+1;

else h(i,j)=0;
l(i,j)的遞推關係
定義mx表示之前0出現的左側位置,初始值=1
if(a[i][j]==0){
l(i,j)=max(l(i-1,j),mx); //mx的值不變 
}else{ //a[i][j]===1,此時的h(i,j)=0,不存在包含(i,j)的子矩陣 
mx=j+1; l(i,j)=1; 
}
r(i,j)的遞推關係
定義mn表示之前0出現的右側位置,初始值=n
if(a[i][j]==0){
r(i,j)=min(mn,r(i-1,j))
}else{
mx=j-1; r(i,j)=n;
}
其中l(i,j),r(i,j),h(i,j)都可以壓縮成一維數組。 
*/

 1 #include <cstdio>
 2 #include <iostream>
 3 using namespace std;
 4 const int maxn=2010;
 5 int n,a[maxn],l[maxn],r[maxn],h[maxn];
 6 int mx,mn,ans;
 7 int main()
 8 {
 9     scanf("%d",&n);
10     for(int col=1;col<=n;col++)
11       l[col]=r[col]=col;
12     for(int row=1;row<=n;row++)
13     {
14         mx=1; mn=n;
15         for(int col=1;col<=n;col++)
16         {
17             scanf("%d",&a[col]);
18             if(a[col]==0)
19               h[col]=h[col]+1;
20             else
21               h[col]=0;
22             if(a[col]==1)
23               mx=col+1;
24             if(a[col]==0)
25               l[col]=max(l[col],mx);
26             else
27               l[col]=1;
28         }
29         for(int col=n;col>0;col--)
30         {
31             if(a[col]==1)
32               mn=col-1;
33             if(a[col]==0)
34               r[col]=min(r[col],mn);
35             else
36               r[col]=n;
37             ans=max(ans,h[col]*(r[col]-l[col]+1));
38         }
39     }
40     printf("%d\n",ans);
41     return 0;
42 }

 




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

-Advertisement-
Play Games
更多相關文章
  • 有這樣的兩個集合: string[] bigArr = new string[] { "a", "b", "c" };string[] smallArr = new string[] { "a", "b"}; 現在需要判斷smallArr是否是bigArr的子集。只要拿著bigArray和small ...
  • 用途:簡化代碼 說明: int a; //a<>null int ?b; //b=null int ?c = b+1; //c=null; int?a=null; int b;(聲明a和b) b=a??2; //b=2; a=6;b=a??8;//b=6; int a=1>0?1:0 //a=1; ...
  • 通過分析源碼可以更好理解List<T>的工作方式,幫助我們寫出更穩定的代碼。 List<T>源碼地址: https://github.com/dotnet/corefx/blob/master/src/System.Collections/src/System/Collections/Generic ...
  • 在很多場合下,我們可能需要利用微信公眾號的優勢,定期給指定用戶群發送一些推廣消息或者新聞內容,以便給關註客戶一種經常更新公眾號內容的感覺,同時也方便我們經常和用戶進行互動。微信公眾號的高級群發介面就是為了處理這個場景的,本文介紹在C#代碼中如何封裝消息的群發和預覽等功能。 1、消息群發的功能和限制 ...
  • vs2012來做一個mvc3的項目,哪知在創建ado數據模型時跳出這麼一個東東 錯 誤: 此模板嘗試載入組件程式集 “NuGet.VisualStudio.Interop, Version=1.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a ...
  • 公司的一個項目由於管理和開發方面的一些問題,導致開發完成之後,一個js文件變的很大,minimize之後還有700kb, 影響了網站的性能,特別是在網速慢的時候,載入一個頁面居然要2分鐘。招來了一大堆的客戶投訴。。。 解決這個問題最理想的辦法是分解這個超大js文件,只載入所需的javascript。 ...
  • 已經可以對excel簡單的操作後 可以開始通過excel寫測試用例 讀取用例 執行用例 提前寫好execl 如圖: 下麵是代碼: 簡單的代碼寫好了 查看運行結果: 自己這個介面自動化測試框架的方向已經看到了 ...
  • 今天集中把幾種排序的方法列一下,當然最出名的希爾,快排,歸併和其優化當然也是滿載 說到希爾排序的話,不得不先提到的就是插入排序了,希爾排序就是對直接插入排序的一種優化,下麵就是直接插入排序的思想 這就是直接插入排序的代碼,思想很簡單,代碼也很簡單 為什麼希爾排序比直接插入排序更加優化呢?當需要排序的 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...