亚马逊经典面试题详解如何深入理解?

2026-05-20 03:321阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计663个文字,预计阅读时间需要3分钟。

亚马逊经典面试题详解如何深入理解?

面试题目:在给定的Map中,0代表海洋,1代表半岛。其中,每个半岛与其八个领域的最小距离可以组成一个半岛群。编写代码,统计Map中半岛的数量。

javaimport java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;

亚马逊经典面试题详解如何深入理解?

public class PeninsulaCounter { private static final int[][] DIRECTIONS={{-1, 0}, {1, 0}, {0, -1}, {0, 1}, {-1, -1}, {-1, 1}, {1, -1}, {1, 1}};

public static void main(String[] args) { String input=[0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0]; Map map=parseInput(input); int peninsulaCount=countPeninsulas(map); System.out.println(Number of peninsulas: + peninsulaCount); }

private static Map parseInput(String input) { Map map=new HashMap(); String[] numbers=input.substring(1, input.length() - 1).split(, ); for (String numStr : numbers) { int num=Integer.parseInt(numStr); if (!map.containsKey(num)) { map.put(num, new ArrayList()); } map.get(num).add(new int[]{num / 10, num % 10}); } return map; }

private static int countPeninsulas(Map map) { int peninsulaCount=0; for (List locations : map.values()) { for (int[] location : locations) { if (isPeninsula(location, map)) { peninsulaCount++; } } } return peninsulaCount; }

private static boolean isPeninsula(int[] location, Map map) { int[] x=location[0]; int[] y=location[1]; for (int[] dir : DIRECTIONS) { int nx=x + dir[0]; int ny=y + dir[1]; if (map.containsKey(nx * 10 + ny) && map.get(nx * 10 + ny).size() > 1) { return true; } } return false; }}

亚马逊面试题:

如下所示的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; }

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

本文共计663个文字,预计阅读时间需要3分钟。

亚马逊经典面试题详解如何深入理解?

面试题目:在给定的Map中,0代表海洋,1代表半岛。其中,每个半岛与其八个领域的最小距离可以组成一个半岛群。编写代码,统计Map中半岛的数量。

javaimport java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;

亚马逊经典面试题详解如何深入理解?

public class PeninsulaCounter { private static final int[][] DIRECTIONS={{-1, 0}, {1, 0}, {0, -1}, {0, 1}, {-1, -1}, {-1, 1}, {1, -1}, {1, 1}};

public static void main(String[] args) { String input=[0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0]; Map map=parseInput(input); int peninsulaCount=countPeninsulas(map); System.out.println(Number of peninsulas: + peninsulaCount); }

private static Map parseInput(String input) { Map map=new HashMap(); String[] numbers=input.substring(1, input.length() - 1).split(, ); for (String numStr : numbers) { int num=Integer.parseInt(numStr); if (!map.containsKey(num)) { map.put(num, new ArrayList()); } map.get(num).add(new int[]{num / 10, num % 10}); } return map; }

private static int countPeninsulas(Map map) { int peninsulaCount=0; for (List locations : map.values()) { for (int[] location : locations) { if (isPeninsula(location, map)) { peninsulaCount++; } } } return peninsulaCount; }

private static boolean isPeninsula(int[] location, Map map) { int[] x=location[0]; int[] y=location[1]; for (int[] dir : DIRECTIONS) { int nx=x + dir[0]; int ny=y + dir[1]; if (map.containsKey(nx * 10 + ny) && map.get(nx * 10 + ny).size() > 1) { return true; } } return false; }}

亚马逊面试题:

如下所示的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; }

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!