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

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

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

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

Q&A

解決済

1回答

3188閲覧

AtCoder ABC049 C問題 白昼夢

shibahama

総合スコア7

C++

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

0グッド

1クリップ

投稿2020/05/21 16:00

編集2020/05/21 16:04

はじめに

閲覧ありがとうございます。AtCoderさんの過去問題で、自分のコードのどこが間違っているのかどうしてもわかりません。間違い箇所の指摘、試すべき事柄の指摘など、なんでもよいのでご教授願います!

問題文

AtCoder Beginners Selectionにも掲載されている、ABC049のC問題、白昼夢です。
https://atcoder.jp/contests/abs/tasks/arc065_a

発生している問題・エラーメッセージ

ACがとれない。
ABC049以前はテストケースが公開されていないようなので、サンプルの他に自作の文字列で何度も試しましたが、正常でした。

該当のソースコード

c++

1#include <bits/stdc++.h> 2 3using namespace std; 4int main() { 5 string S; //入力 6 cin >> S; 7 string a; //Sから末尾を3文字切り取った文字列 8 int n; //Sの文字長 9 10 while(true) { // 11 if(S.size() == 0) { //Sの文字長が0、すなわちSが全て4単語でできていたらYES 12 cout << "YES" << endl; 13 return 0; 14 } 15 n = S.size(); //Sの文字長を取得 16 a = S.substr(n-3, 3); //Sの末尾3文字を取得 17 if(a == "eam") { //Sの末尾3文字を判定、合致したらその単語の長さだけ消去 18 S.erase(n-5, 5); 19 } else if(a == "mer") { 20 S.erase(n-7, 7); 21 } else if(a == "ase") { 22 S.erase(n-5, 5); 23 } else if(a == "ser") { 24 S.erase(n-6, 6); 25 } else { //当てはまらなかったらNO 26 cout << "NO" << endl; 27 return 0; 28 } 29 } 30 31 return 0; 32}

その他

他の方のソースコードをパクれば解決できるのですが、自分のコードの間違いを見つけたいので質問させていただきます。
switch文は文字に使えないようなので、if文を重ねましたが、これもカッコ悪いですよね。。。

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

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

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

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

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

guest

回答1

0

ベストアンサー

末尾3文字だけで判定してしまっているのが問題です。

そのコードだと、例えばhogemerという文字列に対してa == "mer"がtrueになってしまいます。5文字、6文字、7文字と切り取ってみて判定するようにしてみてください。

追記

末尾をn文字切り取る時に、Sがn文字に足りなかったら範囲外アクセスのエラーになります。

例えばS = "ab"という文字列に対してS.substr(n-3, 3);を行おうとすると(私の環境では)libc++abi.dylib: terminating with uncaught exception of type std::out_of_range: basic_stringというエラーが出ます。

文字を切り取る前に、文字列の長さが足りているかも考えなくてはいけないです。

↓AC回答です。手詰まりになったら覗いてみてください
https://atcoder.jp/contests/abs/submissions/13463383

投稿2020/05/21 16:25

編集2020/05/21 16:52
ohys

総合スコア147

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

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

shibahama

2020/05/22 03:12 編集

AC解答拝見しました!わざわざ解いて下さりありがとうございます! 条件演算子?:は初めて見たので、勉強になりました! 結局僕はgoto文でゴリ押すプログラムでAC取れました。(https://atcoder.jp/contests/abs/submissions/13468734 )
ohys

2020/05/22 12:13

お力になれてよかったです!条件演算子はコンパクトに使えば見やすいので私は好きです(何の話だw) お互い頑張っていきましょう!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問