最大矩形

来源:https://www.cnblogs.com/ygjzs/archive/2020/01/27/12235263.html
-Advertisement-
Play Games

"exec的使用文檔" ...


exec的使用文檔

export default (arr) => {
  let result = []
  let reg = /1{2,}/g
  // 把二維數組重新表達,把相鄰的1提取出來
  arr = arr.map(item => {
    let str = item.join('')
    let r = reg.exec(str)
    let rs = []
    while (r) {
      rs.push([r.index, r.index + r[0].length - 1])
      r = reg.exec(str)
    }
    return rs
  })
  // 通過遞歸計算相鄰矩陣
  let maxRect = (arr, result, n = 1) => {
    // 彈出第一行
    let top = arr.pop()
    // 彈出第二行
    let next = arr.pop()
    // 記錄第一行的每一個起始和截止
    let tt
    // 記錄第二行。。。
    let nn
    // 記錄交叉的其實索引
    let start
    // 記錄交叉的截止索引
    let end
    let width = 1
    let maxWidth = 1
    n++
    for (let i = 0, il = top.length; i < il; i++) {
      tt = top[i]
      for (let j = 0, jl = next.length; j < jl; j++) {
        nn = next[j]
        width = Math.min(tt[1], nn[1]) - Math.max(tt[0], nn[0])
        if (width > maxWidth) {
          maxWidth = width
          start = Math.max(tt[0], nn[0])
          end = Math.max(tt[1], nn[1])
        }
      }
    }
    // 沒有交叉點
    if (start === undefined || end === undefined) {
      if (n < 3) {
        return false
      } else {
        width = top[0][1] - top[0][0] + 1
        if (width > 1) {
          result.push((n - 1) * width)
        }
      }
    } else {
      arr.push([[start, end]])
      maxRect(arr, result, n++)
    }
  }
  while (arr.length > 1) {
    // 要值拷貝,因數組在javascript中時引用類型
    maxRect([].concat(arr), result)
    arr.pop()
  }
  let max = 0
  let item = result.pop()
  while (item) {
    if (item > max) {
      max = item
    }
    item = result.pop()
  }
  return max > 0 ? max : -1
}

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

-Advertisement-
Play Games
更多相關文章
  • ![](https://img2018.cnblogs.com/blog/1853166/202001/1853166-20200127184321835-1396957852.png) ![](https://img2018.cnblogs.com/blog/1853166/202001/1853... ...
  • ![](https://img2018.cnblogs.com/blog/1853166/202001/1853166-20200127175727628-1794890893.png) ![](https://img2018.cnblogs.com/blog/1853166/202001/1853... ...
  • ![](https://img2018.cnblogs.com/blog/1853166/202001/1853166-20200127165601485-1997869988.png) ![](https://img2018.cnblogs.com/blog/1853166/202001/1853... ...
  • ![](https://img2018.cnblogs.com/blog/1853166/202001/1853166-20200127153022031-1596993502.png) ![](https://img2018.cnblogs.com/blog/1853166/202001/1853... ...
  • ![](https://img2018.cnblogs.com/blog/1853166/202001/1853166-20200127150544826-1977734878.png) ![](https://img2018.cnblogs.com/blog/1853166/202001/1853... ...
  • javascript中實現一個鏈表的快速排序 ...
  • ![](https://img2018.cnblogs.com/blog/1853166/202001/1853166-20200127125653374-1168375184.png) ![](https://img2018.cnblogs.com/blog/1853166/202001/1853... ...
  • ![](https://img2018.cnblogs.com/blog/1853166/202001/1853166-20200127111253815-61600007.png) ![](https://img2018.cnblogs.com/blog/1853166/202001/185316... ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...