Java
import java.util.Map;
import java.util.HashMap;
/**
* <a href="https://leetcode-cn.com/problems/design-neighbor-sum-service/">Design Neighbor Sum Service</a>
* 设计;数组;哈希表;矩阵;模拟
*/
class NeighborSum {
private int[][] grid;
private Map<Integer, int[]> map; // <num, pos[]{r, c}>
private final int[][][] dirs = {
{{0, 1}, {0, -1}, {1, 0}, {-1, 0}}, // adjacent
{{1, 1}, {1, -1}, {-1, 1}, {-1, -1}} // diagonal
};
public NeighborSum(int[][] grid) {
this.grid = grid;
this.map = new HashMap<>();
for (int i = 0; i < grid.length; i++) {
for (int j = 0; j < grid[0].length; j++) {
map.put(grid[i][j], new int[]{i, j});
}
}
}
public int adjacentSum(int value) {
return getSum(value, 0);
}
public int diagonalSum(int value) {
return getSum(value, 1);
}
private int getSum(int value, int type) {
int[] pos = map.get(value);
int x = pos[0], y = pos[1];
int sum = 0;
for (int[] dir : dirs[type]) {
int nx = x + dir[0], ny = y + dir[1];
if (nx >= 0 && nx < grid.length && ny >= 0 && ny < grid[0].length) {
sum += grid[nx][ny];
}
}
return sum;
}
}