Amazon面试题

标签: 面试题
288人阅读 评论(0) 收藏 举报
分类:

亚马逊面试题:

如下所示的Map中,0代表海水,1代表岛屿,其中每一个岛屿与其八领域的区间的小岛能相连组成岛屿群。写代码,统计Map中岛屿个数。

/*
Q1.
Map
[
0 0 0 0 0 0 0 0
0 1 0 0 0 0 0 0
0 1 1 0 0 0 0 0
0 0 0 0 0 0 1 0
0 0 0 0 0 1 0 0
0 0 0 0 0 0 0 0
]
*/

先直接上代码,后续等我有时间再写解题报告。若有问题,加我公众号留言

#include<iostream>
#include<queue>
using namespace std;

typedef struct {
    int i;
    int j;
}position;

void search(int a[][], int n, int i, int j, int cnt) {

    queue<position> qu = new queue<position>();

    position p;
    p.i = i;
    p.j = j;

    qu.push(p);
    a[i][j] = cnt;

    while (!qu.empty()) {
        p = qu.pop();

        for (int ii = p.i - 1; ii <= p.i + 1; ii++) {
            for (int jj = p.j - 1; jj <= p.j + 1; jj++) {
                if (ii >= 0 && ii < n && jj >= 0 && jj < n && a[ii][jj] == 1 && (ii != i || jj != j)) {
                    a[ii][jj] = cnt;
                    p.i = ii;
                    p.j = jj;
                    qu.push(p);
                }
            }
        }
    }
}

int count(int a[][], int n) {
    int cnt = 1;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            if (a[i][j] == 1) {
                cnt++; // 发现一个新陆地
                search(a, n, i, j, cnt);
            }
        }
    }
    return cnt;
}


int main() {

    int n;
    cin >> n;

    int a[][] = new int[n][n];
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            cin >> a[i][j];
        }
    }

    int cnt = count(a, n);

    cout << cnt - 1 << endl;


    return 0;
}
1
0

猜你在找
【直播】机器学习&数据挖掘7周实训--韦玮
【套餐】系统集成项目管理工程师顺利通关--徐朋
【直播】3小时掌握Docker最佳实战-徐西宁
【套餐】机器学习系列套餐(算法+实战)--唐宇迪
【直播】计算机视觉原理及实战--屈教授
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之矩阵--黄博士
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之凸优化--马博士
【套餐】Javascript 设计模式实战--曾亮
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:97316次
    • 积分:2718
    • 等级:
    • 排名:第13257名
    • 原创:72篇
    • 转载:6篇
    • 译文:4篇
    • 评论:722条
    我的公众号

    博客专栏
    最新评论