質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

1回答

1015閲覧

AtCoder keyence2021 C エラーが出る理由を教えてください

nonoilaoziso

総合スコア19

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2021/01/17 03:06

AtCoder keyence2021 C (https://atcoder.jp/contests/keyence2021) において以下のコードを書きました。方針は解説にあるものと同じです。入力例のうち、1と2では正解を出力するのですが、3では"abort() has been called." とエラーが出ます。これについて少し調べてみたのですが、いまいちよく分かりません。 このエラーについての解説と、できれば私のコードのどの部分がエラーを起こしているのかの指摘を頂きたいです。よろしくお願いします。

コード

C++

1#include <bits/stdc++.h> 2#define _GLIBCXX_DEBUG 3#define rep(i, n) for (int i = 0; i < (int)(n); i++) 4#define rep2(i, s, n) for (int i = (s); i < (int)(n); i++) 5#define all(v) v.begin(), v.end() 6#define pb push_back 7#define sz(x) ((int)(x).size()) 8typedef long long ll; 9using namespace std; 10using Graph = vector<vector<int>>; 11template<class T>bool chmax(T& a, const T& b) { if (a < b) { a = b; return 1; } return 0; } 12template<class T>bool chmin(T& a, const T& b) { if (b < a) { a = b; return 1; } return 0; } 13const ll INF = 1LL << 60; 14 15int H, W, K; vector<vector<char>> grid; vector<vector<vector<ll>>> dp; 16 17vector<ll> rec(int h, int w) { 18 if (dp[h][w][0] != -1) return dp[h][w]; 19 20 vector<ll> res(H * W - K + 1, 0); 21 22 if (h == 0 && w == 0) { 23 res[0] = 1; 24 return res; 25 } 26 27 if (h != 0) { 28 if (grid[h - 1][w] == 'X' || grid[h - 1][w] == 'D') rep(i, H * W - K + 1) res[i] += rec(h - 1, w)[i] % 998244353; 29 if (grid[h - 1][w] == 'O') rep(i, H * W - K) res[i + 1] += rec(h - 1, w)[i] % 998244353; 30 } 31 if (w != 0) { 32 if (grid[h][w - 1] == 'X' || grid[h][w - 1] == 'R') rep(i, H * W - K + 1) res[i] += rec(h, w - 1)[i] % 998244353; 33 if (grid[h][w - 1] == 'O') rep(i, H * W - K) res[i + 1] += rec(h, w - 1)[i] % 998244353; 34 } 35 36 return dp[h][w] = res; 37} 38 39int main() { 40 cin.tie(0); 41 ios::sync_with_stdio(false); 42 43 cin >> H >> W >> K; grid = vector<vector<char>>(H, vector<char>(W, 'O')); 44 rep(i, K) { 45 int h, w; char c; cin >> h >> w >> c; 46 47 grid[h - 1][w - 1] = c; 48 } 49 dp = vector<vector<vector<ll>>>(H, vector<vector<ll>>(W, vector<ll>(H * W - K + 1, -1))); 50 51 vector<ll> fres = rec(H - 1, W - 1); 52 53 ll ans = 0; 54 rep(i, H* W - K + 1) { 55 ans += fres[i] * pow(3, H * W - K - i) * pow(2, i); 56 ans %= 998244353; 57 } 58 59 cout << ans << "\n"; 60 61 return 0; 62}

入力例3
5000 5000 10
585 1323 R
2633 3788 X
1222 4989 D
1456 4841 X
2115 3191 R
2120 4450 X
4325 2864 X
222 3205 D
2134 2388 X
2262 3565 R

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

C++

1 dp = vector<vector<vector<ll>>>(H, vector<vector<ll>>(W, vector<ll>(H * W - K + 1, -1)));

llが8バイト、H=5000,W=5000,K=10で計算すると、この式で必要なメモリは5ペタバイト弱になります。
さすがにこのサイズを確保するのは無理だと思われます。

投稿2021/01/17 04:00

actorbug

総合スコア2224

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問