亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java算法Leecode刷題統(tǒng)計有序矩陣中的負數(shù)

 更新時間:2022年10月08日 16:23:45   作者:可口可鹽  
這篇文章主要為大家介紹了java算法Leecode刷題統(tǒng)計有序矩陣中的負數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

leecode 1351. 統(tǒng)計有序矩陣中的負數(shù)

【Java 刷題打卡】

那就干吧! 這個專欄都是刷的題目都是關(guān)于二分法的,我會由淺入深、循序漸進,刷題就是這樣需要連續(xù)不斷的記憶--艾賓浩斯記憶法2121112。二分法的內(nèi)容不多,但是都是每個程序員必備的

給你一個 m * n 的矩陣 grid,矩陣中的元素無論是按行還是按列,都以非遞增順序排列。 

請你統(tǒng)計并返回 grid 中 負數(shù) 的數(shù)目。

示例 1

輸入:grid = [[4,3,2,-1],[3,2,1,-1],[1,1,-1,-2],[-1,-1,-2,-3]]
輸出:8
解釋:矩陣中共有 8 個負數(shù)。
示例 2:

輸入:grid = [[3,2],[1,0]]
輸出:0
示例 3:

輸入:grid = [[1,-1],[-1,-1]]
輸出:3
示例 4:

輸入:grid = [[-1]]
輸出:1

提示

m == grid.length
n == grid[i].length
1 <= m, n <= 100
-100 <= grid[i][j] <= 100

進階:你可以設(shè)計一個時間復雜度為 O(n + m) 的解決方案嗎?

Morris 遍歷算法整體步驟如下(假設(shè)當前遍歷到的節(jié)點為 x):

如果 x 無左孩子,則訪問 x 的右孩子,即 x = x.right。

如果 x 有左孩子,則找到 x 左子樹上最右的節(jié)點(即左子樹中序遍歷的最后一個節(jié)點,x 在中序遍歷中的前驅(qū)節(jié)點),我們記為 predecessor(前任)。根據(jù)predecessor 的右孩子是否為空,進行如下操作。

  • 如果predecessor 的右孩子為空,則將其右孩子指向 x,然后訪問 x 的左孩子,即 x = x.left。
  • 如果 predecessor 的右孩子不為空,則此時其右孩子指向 x,說明我們已經(jīng)遍歷完 x 的左子樹,我們將 predecessor 的右孩子置空,然后訪問 x 的右孩子,即 x = x.right。

重復上述操作,直至訪問完整棵樹。

其實整個過程我們就多做一步:將當前節(jié)點左子樹中最右邊的節(jié)點指向它,這樣在左子樹遍歷完成后我們通過這個指向走回了 x,且能再通過這個知曉我們已經(jīng)遍歷完成了左子樹,而不用再通過棧來維護,省去了棧的空間復雜度。

了解完這個算法以后,其他地方與方法二并無不同,我們同樣也是維護一個 pred 變量去比較即可,具體實現(xiàn)可以看下面的代碼,這里不再贅述。

參考代碼

定義一顆樹

class TreeNode {
    int val;          // 頭結(jié)點
    TreeNode left;    // 左子樹
    TreeNode right;   // 右子樹
    TreeNode(int x) {
        val = x;
    }
}
// 測試方法
 public static void main(String[] args) {
        TreeNode treeNode = new TreeNode(1);
        treeNode.left = new TreeNode(2);
        treeNode.right = new TreeNode(3);
        System.out.println("xxxx結(jié)果 = " + preorderTraversal(treeNode));
}        

JAVA Morris

class Solution {
    public void recoverTree(TreeNode root) {
        TreeNode x = null, y = null, pred = null, predecessor = null;
        while (root != null) {
            if (root.left != null) {
                // predecessor 節(jié)點就是當前 root 節(jié)點向左走一步,然后一直向右走至無法走為止
                predecessor = root.left;
                while (predecessor.right != null && predecessor.right != root) {
                    predecessor = predecessor.right;
                }
                // 讓 predecessor 的右指針指向 root,繼續(xù)遍歷左子樹
                if (predecessor.right == null) {
                    predecessor.right = root;
                    root = root.left;
                }
                // 說明左子樹已經(jīng)訪問完了,我們需要斷開鏈接
                else {
                    if (pred != null && root.val < pred.val) {
                        y = root;
                        if (x == null) {
                            x = pred;
                        }
                    }
                    pred = root;
                    predecessor.right = null;
                    root = root.right;
                }
            }
            // 如果沒有左孩子,則直接訪問右孩子
            else {
                if (pred != null && root.val < pred.val) {
                    y = root;
                    if (x == null) {
                        x = pred;
                    }
                }
                pred = root;
                root = root.right;
            }
        }
        swap(x, y);
    }
    public void swap(TreeNode x, TreeNode y) {
        int tmp = x.val;
        x.val = y.val;
        y.val = tmp;
    }
}

以上就是java算法Leecode刷題統(tǒng)計有序矩陣中的負數(shù)的詳細內(nèi)容,更多關(guān)于java算法統(tǒng)計有序矩陣負數(shù)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Java NIO無法綁定指定IP和端口解決方案

    Java NIO無法綁定指定IP和端口解決方案

    這篇文章主要介紹了Java NIO無法綁定指定IP和端口解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • 淺談SpringBoot如何自定義Starters

    淺談SpringBoot如何自定義Starters

    今天帶大家來學習SpringBoot如何自定義Starters,文中有非常詳細的圖文介紹及代碼示例,對正在學習java的小伙伴們很有幫助,需要的朋友可以參考下
    2021-05-05
  • Java多維數(shù)組詳解

    Java多維數(shù)組詳解

    大家好,本篇文章主要講的是Java多維數(shù)組詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • 遞歸之斐波那契數(shù)列java的3種方法

    遞歸之斐波那契數(shù)列java的3種方法

    這篇文章主要為大家詳細介紹了遞歸之斐波那契數(shù)列java的3種方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • JavaWeb框架MVC設(shè)計思想詳解

    JavaWeb框架MVC設(shè)計思想詳解

    這篇文章主要介紹了JavaWeb框架MVC設(shè)計思想詳解的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-07-07
  • Java內(nèi)存溢出場景及解決方案

    Java內(nèi)存溢出場景及解決方案

    內(nèi)存溢出是Java應(yīng)用開發(fā)中常見的問題,但通過合理的代碼優(yōu)化、內(nèi)存管理以及JVM參數(shù)調(diào)整,我們可以有效地避免和解決這類問題,這篇文章主要介紹了Java內(nèi)存溢出場景及解決辦法,需要的朋友可以參考下
    2024-04-04
  • java循環(huán)練習的簡單代碼實例

    java循環(huán)練習的簡單代碼實例

    本篇文章介紹了,java中循環(huán)練習的一些簡單代碼實例。需要的朋友參考下
    2013-04-04
  • 詳解JavaEE 使用 Redis 數(shù)據(jù)庫進行內(nèi)容緩存和高訪問負載

    詳解JavaEE 使用 Redis 數(shù)據(jù)庫進行內(nèi)容緩存和高訪問負載

    本篇文章主要介紹了JavaEE 使用 Redis 數(shù)據(jù)庫進行內(nèi)容緩存和高訪問負載,具有一定的參考價值,有興趣的可以了解一下
    2017-08-08
  • Java線性表的順序表示及實現(xiàn)

    Java線性表的順序表示及實現(xiàn)

    這篇文章主要介紹了Java線性表的順序表示及實現(xiàn),順序表是在計算機內(nèi)存中以數(shù)組的形式保存的線性表,線性表的順序存儲是指用一組地址連續(xù)的存儲單元依次存儲線性表中的各個元素、使得線性表中在邏輯結(jié)構(gòu)上相鄰的數(shù)據(jù)元素存儲在相鄰的物理存儲單元中
    2022-07-07
  • 解決MyBatis中為類配置別名,列名與屬性名不對應(yīng)的問題

    解決MyBatis中為類配置別名,列名與屬性名不對應(yīng)的問題

    這篇文章主要介紹了解決MyBatis中為類配置別名,列名與屬性名不對應(yīng)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11

最新評論