亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

求最大全1子矩陣中1的個數

求最大全1子矩陣中1的個數

ibeautiful 2018-12-18 17:18:38
給定一個01矩陣map,求其中全是1的子矩陣里1的最大個數。例如:1 1 1 0其中最大的全1子矩陣有3個1,返回3.1 0 1 11 1 1 11 1 1 0其中最大的全1子矩陣有6個1,返回6.對于N*M的01矩陣,求時間復雜度為O(N*M)的Javascript實現方案
查看完整描述

1 回答

?
蝴蝶刀刀

TA貢獻1801條經驗 獲得超8個贊

function getMaxMatrix(map){

    if(map == null || map.length == 0 || map[0].length == 0) return 0;

    var maxArea = 0;

    var height = [];

    for(var k = 0; k < map[0].length; k++){

        height[k] = 0;

    }


    for(var i = 0; i < map.length; i++){

        for(var j = 0; j < map[0].length; j++){

            height[j] = map[i][j] == 0 ? 0 : height[j] + 1;

        }

        maxArea = Math.max(maxMatrixFromBottom(height), maxArea);

    }

    return maxArea;

}


function maxMatrixFromBottom(height){

    if(height == null || height.length == 0) return 0;

    var maxArea = 0;

    var stack = [];

    for(var i = 0; i < height.length; i++){

        while(stack.length != 0 && height[i] <= height[stack[stack.length - 1]]){

            var j = stack.pop();

            var k = stack.length == 0 ? -1 : stack[stack.length - 1];

            var curArea = (i - k -1) * height[j];

            maxArea = Math.max(maxArea, curArea);

        }

        stack.push(i);

    }

    while(stack.length != 0){

        var j = stack.pop();

        var k = stack.length == 0 ? -1 : stack[stack.length - 1];

        var curArea = (i - k -1) * height[j];

        maxArea = Math.max(maxArea, curArea);

    }

    return maxArea;

}


var map =[

    [1,1,1,1],

    [1,1,1,1],

    [1,0,0,0]

  ];

console.log(getMaxMatrix(map))


查看完整回答
反對 回復 2019-01-05
  • 1 回答
  • 0 關注
  • 643 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號