亚马逊经典面试题实例详解
亚马逊面试题:
如下所示的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; }
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
上一篇:C经典算法之二分查找法
栏 目:C语言
下一篇:c++难以发现的bug(有趣)
本文标题:亚马逊经典面试题实例详解
本文地址:https://www.xiuzhanwang.com/a1/Cyuyan/1120.html
您可能感兴趣的文章
- 01-10探讨:用两个栈实现一个队列(我作为面试官的小结)
- 01-10C++ 创建桌面快捷方式 开始菜单的实现代码
- 01-10C语言程序设计50例(经典收藏)
- 01-10C与C++ 无参函数的区别解析
- 01-10浅析c/c++中函数的参数传递
- 01-10一道超经典的C++结构体的题目
- 01-10c字符串,string对象,字符串字面值的区别详解
- 01-10全面解析C++中的new,operator new与placement new
- 01-10shared_ptr线程安全性全面分析
- 01-10头文件不宜定义变量的原因全面解析
阅读排行
本栏相关
- 04-02c语言函数调用后清空内存 c语言调用
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言的正则匹配函数 c语言正则表达
- 04-02c语言用函数写分段 用c语言表示分段
- 04-02c语言中对数函数的表达式 c语言中对
- 04-02c语言编写函数冒泡排序 c语言冒泡排
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段
- 04-02C语言中怎么打出三角函数 c语言中怎
- 04-02c语言调用函数求fibo C语言调用函数求
随机阅读
- 04-02jquery与jsp,用jquery
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法实例总结
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 01-11ajax实现页面的局部加载
- 01-10SublimeText编译C开发环境设置
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文