码迷,mamicode.com
首页 > 其他好文 > 详细

宝岛探险

时间:2018-07-21 14:45:13      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:new   int   深度优先搜索   初始   题目   上下左右   测试   ack   ++   

原创


题目大意:

  钓鱼岛由一个主岛和一些附属岛屿组成,小明决定去钓鱼岛探险。下面这个10*10的二维矩阵就是钓鱼岛

的航拍地图。图中数字表示海拔,0表示海洋,1~9都表示陆地。小明的飞机将会降落在(6,8)处,现在需要

计算出小明将落地所在岛的面积(即有多少个格子)。注意此处把与小明降落点上下左右相链接的陆地视为同

一岛屿。

技术分享图片

 题意很简单,即给出一个点,求这个点所在的岛屿即可。数字只要不是0,都不用理会大小。

思路很直观,直接BFS。

import java.util.*;

public class 宝岛探险 {
    
    static int total=0;    //统计岛屿面积
    static int n;    //
    static int m;    //
    static int start_x;    //初始位置
    static int start_y;
    static int x[];    //队列横坐标
    static int y[];    //队列纵坐标
    static int maze[][];
    static int book[][];    //标记

    public static void main(String[] args) {
        
        Scanner reader=new Scanner(System.in);
        n=reader.nextInt();
        m=reader.nextInt();
        start_x=reader.nextInt();
        start_y=reader.nextInt();
        maze=new int[n][m];
        book=new int[n][m];
        x=new int[n*m];
        y=new int[n*m];
        int dir[][]= { {0,1},{1,0},{0,-1},{-1,0} };    //右、下、左、上
        int head=0;
        int tail=0;
        for(int i=0;i<n;i++) {
            for(int j=0;j<m;j++) {
                maze[i][j]=reader.nextInt();
                book[i][j]=0;    //数组初始化
            }
        }
        //初始位置入队列
        x[tail]=start_x;
        y[tail]=start_y;
        book[start_x][start_y]=1;
        tail++;
        total++;
        while(head<tail) {
            for(int i=0;i<4;i++) {
                int dx=x[head]+dir[i][0];
                int dy=y[head]+dir[i][1];
                if(dx<0 || dx>n-1 || dy<0 || dy>m-1) {    //越界判断
                    continue;
                }
                if(maze[dx][dy]==0 || book[dx][dy]==1) {
                    continue;
                }
                x[tail]=dx;
                y[tail]=dy;
                tail++;
                book[dx][dy]=1;
                total++;
            }
            head++;    //出队列
        }
        System.out.println(total);
    }
}

深度优先搜索也可以,重点是由于每个点只可以统计一次,所以不需要回溯!

import java.util.*;

public class 宝岛探险2 {
    
    static int total=1;
    static int n;
    static int m;
    static int start_x;
    static int start_y;
    static int maze[][];
    static int book[][];
    static int dir[][]= { {0,1},{1,0},{0,-1},{-1,0} };    //右、下、左、上
    
    static void dfs(int x,int y) {
        
        for(int i=0;i<4;i++) {
            int dx=x+dir[i][0];
            int dy=y+dir[i][1];
            if(dx<0 || dx>n-1 || dy<0 || dy>m-1) {
                continue;
            }
            if(maze[dx][dy]==0 ||book[dx][dy]==1) {
                continue;
            }
            total++;
            book[dx][dy]=1;
            dfs(dx,dy);
        }
        
    }

    public static void main(String[] args) {
        
        Scanner reader=new Scanner(System.in);
        n=reader.nextInt();
        m=reader.nextInt();
        start_x=reader.nextInt();
        start_y=reader.nextInt();
        maze=new int[n][m];
        book=new int[n][m];
        for(int i=0;i<n;i++) {
            for(int j=0;j<m;j++) {
                maze[i][j]=reader.nextInt();
                book[i][j]=0;
            }
        }
        book[start_x][start_y]=1;
        dfs(start_x,start_y);
        System.out.println(total);
    }

}

测试用例:

10 10 6 8
1 2 1 0 0 0 0 0 2 3
3 0 2 0 1 2 1 0 1 2
4 0 1 0 1 2 3 2 0 1
3 2 0 0 0 1 2 4 0 0
0 0 0 0 0 0 1 5 3 0
0 1 2 1 0 1 5 4 3 0
0 1 2 3 1 3 6 2 1 0
0 0 3 4 8 9 7 5 0 0
0 0 0 3 7 8 6 0 1 2
0 0 0 0 0 0 0 0 1 0

输出:38

11:58:54

2018-07-21

宝岛探险

标签:new   int   深度优先搜索   初始   题目   上下左右   测试   ack   ++   

原文地址:https://www.cnblogs.com/chiweiming/p/9343905.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!