⬆︎
×

[LC] 3242 Design Neighbor Sum Service

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;
    }
}

发表评论