国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

算法leetcode|73. 矩陣置零(rust重拳出擊)

這篇具有很好參考價值的文章主要介紹了算法leetcode|73. 矩陣置零(rust重拳出擊)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。



73. 矩陣置零:

給定一個 m x n 的矩陣,如果一個元素為 0 ,則將其所在行和列的所有元素都設(shè)為 0 。請使用 原地 算法。

樣例 1:

算法leetcode|73. 矩陣置零(rust重拳出擊),LeetCode力扣算法題目,rust,golang,數(shù)據(jù)結(jié)構(gòu),算法,后端,leetcode

輸入:
	
	matrix = [[1,1,1],[1,0,1],[1,1,1]]
	
輸出:
	
	[[1,0,1],[0,0,0],[1,0,1]]

樣例 2:

算法leetcode|73. 矩陣置零(rust重拳出擊),LeetCode力扣算法題目,rust,golang,數(shù)據(jù)結(jié)構(gòu),算法,后端,leetcode

輸入:
	
	matrix = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]
	
輸出:
	
	[[0,0,0,0],[0,4,5,0],[0,3,1,0]]

提示:

  • m == matrix.length
  • n == matrix[0].length
  • 1 <= m, n <= 200
  • -231 <= matrix[i][j] <= 231 - 1

進階:

  • 一個直觀的解決方案是使用 O(mn) 的額外空間,但這并不是一個好的解決方案。
  • 一個簡單的改進方案是使用 O(m + n) 的額外空間,但這仍然不是最好的解決方案。
  • 你能想出一個僅使用常量空間的解決方案嗎?

分析:

  • 面對這道算法題目,二當家的再次陷入了沉思。
  • 要遍歷整個矩陣是肯定的了,所以時間復雜度上似乎沒什么大的技巧,重點在空間復雜度上。
  • 不使用額外空間,直接在遍歷中就將行和列置0,會導致還沒有遍歷到的值丟失。
  • 可以將原矩陣整體拷貝一份作為備份,然后遍歷這個備份的矩陣,去直接將原矩陣置0,這樣會使用 O(mn) 的額外空間。
  • 一個簡單的改進方案是使用兩個額外的數(shù)組,存儲每一行是否出現(xiàn)過0,和每一列是否出現(xiàn)過0,然后再利用這兩個額外的標記數(shù)組將原矩陣置0,這樣會使用 O(m + n) 的額外空間。
  • 可以進一步優(yōu)化,我們可以用矩陣的第一行和第一列代作為標記數(shù)組。但這樣會導致原數(shù)組的第一行和第一列被修改,無法記錄它們是否原本包含 0。因此我們需要額外使用兩個標記變量分別記錄第一行和第一列是否原本包含 0,這樣僅僅需要 O(1) 的額外空間。

題解:

rust:

impl Solution {
    pub fn set_zeroes(matrix: &mut Vec<Vec<i32>>) {
        let (m, n) = (matrix.len(), matrix[0].len());
        let (mut flag_row0, mut flag_col0) = (false, false);
        // 第一行是否有0
        for i in 0..n {
            if matrix[0][i] == 0 {
                flag_row0 = true;
                break;
            }
        }
        // 第一列是否有0
        for i in 0..m {
            if matrix[i][0] == 0 {
                flag_col0 = true;
                break;
            }
        }
        // 標記
        (1..m).for_each(|i| {
            (1..n).for_each(|j| {
                if matrix[i][j] == 0 {
                    matrix[i][0] = 0;
                    matrix[0][j] = 0;
                }
            });
        });
        // 置0
        (1..m).for_each(|i| {
            (1..n).for_each(|j| {
                if matrix[i][0] == 0 || matrix[0][j] == 0 {
                    matrix[i][j] = 0;
                }
            });
        });
        // 第一行置0
        if flag_row0 {
            for i in 0..n {
                matrix[0][i] = 0;
            }
        }
        // 第一列置0
        if flag_col0 {
            for i in 0..m {
                matrix[i][0] = 0;
            }
        }
    }
}

go:

func setZeroes(matrix [][]int)  {
    m, n := len(matrix), len(matrix[0])
	row0, col0 := false, false
	// 第一行是否有0
	for _, v := range matrix[0] {
		if v == 0 {
			row0 = true
			break
		}
	}
	// 第一列是否有0
	for _, r := range matrix {
		if r[0] == 0 {
			col0 = true
			break
		}
	}
	// 標記
	for i := 1; i < m; i++ {
		for j := 1; j < n; j++ {
			if matrix[i][j] == 0 {
				matrix[i][0] = 0
				matrix[0][j] = 0
			}
		}
	}
	// 置0
	for i := 1; i < m; i++ {
		for j := 1; j < n; j++ {
			if matrix[i][0] == 0 || matrix[0][j] == 0 {
				matrix[i][j] = 0
			}
		}
	}
	// 第一行置0
	if row0 {
		for i := 0; i < n; i++ {
			matrix[0][i] = 0
		}
	}
	// 第一列置0
	if col0 {
		for _, r := range matrix {
			r[0] = 0
		}
	}
}

c++:

class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        const int m = matrix.size(), n = matrix[0].size();
        bool flag_row0 = false, flag_col0 = false;
        // 第一行是否有0
        for (int i = 0; i < n; ++i) {
            if (!matrix[0][i]) {
                flag_row0 = true;
                break;
            }
        }
        // 第一列是否有0
        for (int i = 0; i < m; ++i) {
            if (!matrix[i][0]) {
                flag_col0 = true;
                break;
            }
        }
        // 標記
        for (int i = 1; i < m; ++i) {
            for (int j = 1; j < n; ++j) {
                if (!matrix[i][j]) {
                    matrix[i][0] = matrix[0][j] = 0;
                }
            }
        }
        // 置0
        for (int i = 1; i < m; ++i) {
            for (int j = 1; j < n; ++j) {
                if (!matrix[i][0] || !matrix[0][j]) {
                    matrix[i][j] = 0;
                }
            }
        }
        // 第一行置0
        if (flag_row0) {
            for (int i = 0; i < n; ++i) {
                matrix[0][i] = 0;
            }
        }
        // 第一列置0
        if (flag_col0) {
            for (int i = 0; i < m; ++i) {
                matrix[i][0] = 0;
            }
        }
    }
};

python:

class Solution:
    def setZeroes(self, matrix: List[List[int]]) -> None:
        """
        Do not return anything, modify matrix in-place instead.
        """
        m, n = len(matrix), len(matrix[0])
        # 第一行是否有0
        flag_row0 = any(matrix[0][i] == 0 for i in range(n))
        # 第一列是否有0
        flag_col0 = any(matrix[i][0] == 0 for i in range(m))
        # 標記
        for i in range(1, m):
            for j in range(1, n):
                if matrix[i][j] == 0:
                    matrix[i][0] = matrix[0][j] = 0
        # 置0
        for i in range(1, m):
            for j in range(1, n):
                if matrix[i][0] == 0 or matrix[0][j] == 0:
                    matrix[i][j] = 0
        # 第一行置0
        if flag_row0:
            for j in range(n):
                matrix[0][j] = 0
        # 第一列置0
        if flag_col0:
            for i in range(m):
                matrix[i][0] = 0


java:

class Solution {
    public void setZeroes(int[][] matrix) {
        final int m        = matrix.length, n = matrix[0].length;
        boolean   flagRow0 = false, flagCol0 = false;
        // 第一行是否有0
        for (int i = 0; i < m; ++i) {
            if (matrix[i][0] == 0) {
                flagCol0 = true;
                break;
            }
        }
        // 第一列是否有0
        for (int i = 0; i < n; ++i) {
            if (matrix[0][i] == 0) {
                flagRow0 = true;
                break;
            }
        }
        // 標記
        for (int i = 1; i < m; ++i) {
            for (int j = 1; j < n; ++j) {
                if (matrix[i][j] == 0) {
                    matrix[i][0] = matrix[0][j] = 0;
                }
            }
        }
        // 置0
        for (int i = 1; i < m; ++i) {
            for (int j = 1; j < n; ++j) {
                if (matrix[i][0] == 0 || matrix[0][j] == 0) {
                    matrix[i][j] = 0;
                }
            }
        }
        // 第一行置0
        if (flagRow0) {
            for (int i = 0; i < n; ++i) {
                matrix[0][i] = 0;
            }
        }
        // 第一列置0
        if (flagCol0) {
            for (int i = 0; i < m; ++i) {
                matrix[i][0] = 0;
            }
        }
    }
}

非常感謝你閱讀本文~
歡迎【點贊】【收藏】【評論】三連走一波~
放棄不難,但堅持一定很酷~
希望我們大家都能每天進步一點點~
本文由 二當家的白帽子:https://le-yi.blog.csdn.net/ 博客原創(chuàng)~文章來源地址http://www.zghlxwxcb.cn/news/detail-672599.html


到了這里,關(guān)于算法leetcode|73. 矩陣置零(rust重拳出擊)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • 算法leetcode|57. 插入?yún)^(qū)間(rust重拳出擊)

    給你一個 無重疊的 ,按照區(qū)間起始端點排序的區(qū)間列表。 在列表中插入一個新的區(qū)間,你需要確保列表中的區(qū)間仍然有序且不重疊(如果有必要的話,可以合并區(qū)間)。 0 = intervals.length = 10 4 intervals[i].length == 2 0 = intervals[i][0] = intervals[i][1] = 10 5 intervals 根據(jù) intervals[i][0] 按

    2024年02月09日
    瀏覽(24)
  • 算法leetcode|60. 排列序列(rust重拳出擊)

    給出集合 [1,2,3,...,n] ,其所有元素共有 n! 種排列。 按大小順序列出所有排列情況,并一一標記,當 n = 3 時, 所有排列如下: \\\"123\\\" \\\"132\\\" \\\"213\\\" \\\"231\\\" \\\"312\\\" \\\"321\\\" 給定 n 和 k ,返回第 k 個排列。 1 = n = 9 1 = k = n! 面對這道算法題目,二當家的再次陷入了沉思。 如果模擬,按順序生成k個

    2024年02月12日
    瀏覽(19)
  • 算法leetcode|62. 不同路徑(rust重拳出擊)

    算法leetcode|62. 不同路徑(rust重拳出擊)

    一個機器人位于一個 m x n 網(wǎng)格的左上角 (起始點在下圖中標記為 “Start” )。 機器人每次只能向下或者向右移動一步。機器人試圖達到網(wǎng)格的右下角(在下圖中標記為 “Finish” )。 問總共有多少條不同的路徑? 1 = m, n = 100 題目數(shù)據(jù)保證答案小于等于 2 * 10 9 面對這道算法

    2024年02月17日
    瀏覽(23)
  • 算法leetcode|85. 最大矩形(rust重拳出擊)

    算法leetcode|85. 最大矩形(rust重拳出擊)

    給定一個僅包含 0 和 1 、大小為 rows x cols 的二維二進制矩陣,找出只包含 1 的最大矩形,并返回其面積。 rows == matrix.length cols == matrix[0].length 1 = row, cols = 200 matrix[i][j] 為 ‘0’ 或 ‘1’ 面對這道算法題目,二當家的再次陷入了沉思。 要不是剛做過 84. 柱狀圖中最大的矩形 這

    2024年02月08日
    瀏覽(17)
  • 算法leetcode|89. 格雷編碼(rust重拳出擊)

    n 位格雷碼序列 是一個由 2 n 個整數(shù)組成的序列,其中: 每個整數(shù)都在范圍 [0, 2 n - 1] 內(nèi)(含 0 和 2 n - 1) 第一個整數(shù)是 0 一個整數(shù)在序列中出現(xiàn) 不超過一次 每對 相鄰 整數(shù)的二進制表示 恰好一位不同 ,且 第一個 和 最后一個 整數(shù)的二進制表示 恰好一位不同 給你一個整數(shù)

    2024年02月04日
    瀏覽(29)
  • 算法leetcode|71. 簡化路徑(rust重拳出擊)

    給你一個字符串 path ,表示指向某一文件或目錄的 Unix 風格 絕對路徑 (以 \\\'/\\\' 開頭),請你將其轉(zhuǎn)化為更加簡潔的規(guī)范路徑。 在 Unix 風格的文件系統(tǒng)中,一個點( . )表示當前目錄本身;此外,兩個點 ( .. ) 表示將目錄切換到上一級(指向父目錄);兩者都可以是復雜相

    2024年02月12日
    瀏覽(19)
  • 算法leetcode|75. 顏色分類(rust重拳出擊)

    給定一個包含紅色、白色和藍色、共 n 個元素的數(shù)組 nums , 原地 對它們進行排序,使得相同顏色的元素相鄰,并按照紅色、白色、藍色順序排列。 我們使用整數(shù) 0 、 1 和 2 分別表示紅色、白色和藍色。 必須在不使用庫內(nèi)置的 sort 函數(shù)的情況下解決這個問題。 n == nums.length

    2024年02月10日
    瀏覽(16)
  • 算法leetcode|65. 有效數(shù)字(rust重拳出擊)

    算法leetcode|65. 有效數(shù)字(rust重拳出擊)

    有效數(shù)字 (按順序)可以分成以下幾個部分: 一個 小數(shù) 或者 整數(shù) (可選)一個 \\\'e\\\' 或 \\\'E\\\' ,后面跟著一個 整數(shù) 小數(shù) (按順序)可以分成以下幾個部分: (可選)一個符號字符( \\\'+\\\' 或 \\\'-\\\' ) 下述格式之一: 至少一位數(shù)字,后面跟著一個點 \\\'.\\\' 至少一位數(shù)字,后面跟著一個

    2024年02月15日
    瀏覽(20)
  • 算法leetcode|91. 解碼方法(rust重拳出擊)

    一條包含字母 A-Z 的消息通過以下映射進行了 編碼 : 要 解碼 已編碼的消息,所有數(shù)字必須基于上述映射的方法,反向映射回字母(可能有多種方法)。例如, \\\"11106\\\" 可以映射為: \\\"AAJF\\\" ,將消息分組為 (1 1 10 6) \\\"KJF\\\" ,將消息分組為 (11 10 6) 注意,消息不能分組為 (1 11 06) ,因

    2024年02月05日
    瀏覽(19)
  • 算法leetcode|79. 單詞搜索(rust重拳出擊)

    算法leetcode|79. 單詞搜索(rust重拳出擊)

    給定一個 m x n 二維字符網(wǎng)格 board 和一個字符串單詞 word 。如果 word 存在于網(wǎng)格中,返回 true ;否則,返回 false 。 單詞必須按照字母順序,通過相鄰的單元格內(nèi)的字母構(gòu)成,其中“相鄰”單元格是那些水平相鄰或垂直相鄰的單元格。同一個單元格內(nèi)的字母不允許被重復使用。

    2024年02月09日
    瀏覽(21)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包