結果
| 問題 |
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';
}
}