91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android島嶼數量算法怎么使用

發布時間:2023-03-01 11:29:15 來源:億速云 閱讀:227 作者:iii 欄目:開發技術

這篇文章主要介紹“Android島嶼數量算法怎么使用”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Android島嶼數量算法怎么使用”文章能幫助大家解決問題。

島嶼數量

之前接觸過一個算法,比較有意思,可以拿出來說說,這個算法是這樣的。

給一個01矩陣,1代表是陸地,0代表海洋, 如果兩個1相鄰,那么這兩個1屬于同一個島。我們只考慮上下左右為相鄰。(島嶼: 相鄰陸地可以組成一個島嶼(相鄰:上下左右) 判斷島嶼個數。)

比如

輸入

[
[1,1,0,0,0],
[0,1,0,1,1],
[0,0,0,1,1],
[0,0,0,0,0],
[0,0,1,1,1]
]

輸出3。因為1相連的就3塊

那這道題要如何做呢,其實有個思路,我去遍歷二維數組,判斷到如果為1,我就把與1相連的上下左右都置0,這樣在接下來的遍歷中就不會受到已統計數量的影響。

如果只聽這樣的描述還是沒理解也沒關系,可以看看代碼,我這是用java寫的,挺簡單的,應該能很容易看懂。

public class Solution {
    /**
     * 判斷島嶼數量
     * @param grid char字符型二維數組
     * @return int整型
     */
    public int solve (char[][] grid) {
        int total = 0;
        if(grid.length == 0 || grid[0].length == 0){
            return total;
        }
        int wl = grid[0].length;
        for(int i=0; i < grid.length; i++){
            for(int j =0; j < wl; j++){
                if(grid[i][j] == '1'){
                    total++;
                    cancel(grid, i, j);
                }
            }
        }
        return total;
    }
    private void cancel(char[][] grid, int i, int j){
        if(grid[i][j] == '1'){
            grid[i][j] = '0';
            if(i > 0){
                cancel(grid, i-1, j);
            }
            if(j > 0){
                cancel(grid, i, j-1);
            }
            if(j < grid[0].length -1){
                cancel(grid, i, j+1);
            }
            if(i < grid.length - 1){
                cancel(grid, i+1, j);
            }
        }
    }
}

那能從這個算法中學會什么呢?學會了這道算法,被問到就有題庫了【狗頭】,那也太血虧了,還是要擴展一下思路。

我覺得有意思的地方在于,它是通過一個反向的思路,去設置狀態,以此來把這個問題變得更簡單。

有個比較基礎的坑,在循環中刪除元素,這是會出問題的。假設我有一堆學生,我生日了要發出邀請,我想把所有的男生都給排除掉。

public class Student {
    public int sex; // 男是1
}
List<Student> students = new getAllStudents();
for (int i = 0; i < students.size(); i++) {
    if (students.get(i).sex == 1){
        students.remove(students.get(i));
    }
}

這樣寫肯定會出問題,這是一個也算是經典的BUG場景了,相信所有人都碰到過。因為我們的思路是“排除所有男生”,但是如果反著去想,這個問題也就很好解決,反著就是“保留所有女生”

List<Student> students = new getAllStudents();
List<Student> girls = new ArrayList<>();
for (int i = 0; i < students.size(); i++) {
    if (students.get(i).sex == 0){
        girls.add(students.get(i));
    }
}
students = girls;

應該沒什么問題吧,我直接就在這寫了,類似偽代碼那種,大概懂什么意思就行,這個其實就是copy and write

雖然這個場景可能不能很好的表現出這個思路,但是意思就是如果我們開發中碰到一些問題或者復雜的邏輯流程,我們可以試著反著思考,說不定會有更好的出路。

關于“Android島嶼數量算法怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

衡阳市| 铜山县| 昭苏县| 云和县| 儋州市| 辽源市| 改则县| 乌拉特前旗| 巴彦淖尔市| 贵州省| 玉山县| 阿坝县| 巴马| 科技| 汾阳市| 台安县| 通化县| 上高县| 寿光市| 板桥市| 教育| 麦盖提县| 清镇市| 东方市| 淮南市| 盐城市| 阿坝| 会东县| 邹城市| 喀喇沁旗| 海原县| 新蔡县| 洮南市| 手机| 漳浦县| 吕梁市| 崇阳县| 石嘴山市| 威海市| 达州市| 安多县|