結果
問題 |
No.1141 田グリッド
|
ユーザー |
|
提出日時 | 2025-10-20 22:26:23 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 54 ms / 2,000 ms |
コード長 | 1,135 bytes |
コンパイル時間 | 2,479 ms |
コンパイル使用メモリ | 287,048 KB |
実行使用メモリ | 16,768 KB |
最終ジャッジ日時 | 2025-10-20 22:26:30 |
合計ジャッジ時間 | 5,644 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 31 |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; #define rep(i, s, e) for (int i = (int)(s); i < (int)(e); ++i) #include <atcoder/modint> using namespace atcoder; using mint = modint1000000007; vector<int> di = {-1, -1, 1, 1}; vector<int> dj = {-1, 1, 1, -1}; int main() { cin.tie(nullptr); ios_base::sync_with_stdio(false); int H, W; cin >> H >> W; vector A(4, vector(H, vector<mint>(W))); rep(i, 0, H) rep(j, 0, W) { int t; cin >> t; rep(k, 0, 4) A[k][i][j] = t; } rep(i, 1, H) rep(j, 0, W) { A[0][i][j] *= A[0][i - 1][j]; A[1][i][j] *= A[1][i - 1][j]; A[2][H - i - 1][j] *= A[2][H - i][j]; A[3][H - i - 1][j] *= A[3][H - i][j]; } rep(i, 0, H) rep(j, 1, W) { A[0][i][j] *= A[0][i][j - 1]; A[1][i][W - j - 1] *= A[1][i][W - j]; A[2][i][W - j - 1] *= A[2][i][W - j]; A[3][i][j] *= A[3][i][j - 1]; } int Q; cin >> Q; for (;Q--;) { int r, c; cin >> r >> c; --r, --c; mint ans = 1; rep(dir, 0, 4) { int i = r + di[dir]; int j = c + dj[dir]; if (i < 0 || H <= i || j < 0 || W <= j) continue; ans *= A[dir][i][j]; } cout << ans.val() << '\n'; } }