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

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

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

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

Q&A

解決済

1回答

1418閲覧

AtCoder ABC006 「D_トランプ挿入ソート」について

Python-Beginner

総合スコア17

C++

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

1グッド

1クリップ

投稿2020/05/31 06:56

AtCoder ABCのD問題「トランプ挿入ソート」について、
作成したソースコードの問題箇所をご教示いただけないでしょうか。
問題文(ABC006 D)へのリンク

作成した下記のソースコードを提出したところ、約1割ほどのテストケースが通りませんでした。自身では問題箇所を特定できず、完全に行き詰まってしまったため、問題箇所をご教示いただけると幸甚でございます。

解放の方針は、①LISを求める。②トランプの枚数からLISを引く。という単純な内容でございます。大雑把な質問で恐縮ですが、どうぞよろしくお願いいたします。

c++

1#include <bits/stdc++.h> 2using namespace std; 3const int INF = 1000000; 4 5int dp[1010]; 6 7int b_search(int ng, int ok, int target) 8{ 9 while (ng + 1 < ok) 10 { 11 int mid = (ng + ok) / 2; 12 if (dp[mid] >= target) 13 { 14 ok = mid; 15 } 16 else 17 { 18 ng = mid; 19 } 20 } 21 22 return ok; 23} 24 25int main() 26{ 27 int n; 28 cin >> n; 29 30 // DPの初期化 31 for (int i = 0; i < n; i++) 32 { 33 dp[i] = INF; 34 } 35 36 int cnt = 0; 37 for (int i = 0; i < n; i++) 38 { 39 int a; 40 cin >> a; 41 if (i == 0) 42 { 43 dp[0] = a; 44 continue; 45 } 46 47 if (dp[i - 1] < a) 48 { 49 dp[i] = a; 50 } 51 else 52 { 53 dp[b_search(-1, i - 1, a)] = a; 54 } 55 } 56 57 int lis = 0; 58 for (int i = 0; i < n; i++) 59 { 60 if (dp[i] == INF) 61 break; 62 lis++; 63 } 64 65 cout << n - lis << endl; 66 return 0; 67}

イメージ説明

DrqYuto👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

配列の確保サイズが小さすぎます
それでREになってるんでしょう

投稿2020/05/31 09:49

yudedako67

総合スコア2047

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

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

Python-Beginner

2020/06/01 12:56

ご指摘の通り、配列のサイズが間違っておりました。 ご教示くださり、ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問