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

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

新規登録して質問してみよう
ただいま回答率
85.35%
アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

2028閲覧

Python 逆ポーランド記法 計算アルゴリズム

eguti

総合スコア1

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/11/18 08:42

前提・実現したいこと

ここに質問の内容を詳しく書いてください。
Pythonの質問です。
逆ポーランド記法で書かれた 2 1 + のような式の答えを表示させるようにしたい

①計算の際には,スタックから2つの数字(stack[0]とstack[1])を取り出し,計算を行う.
②計算が終了したら,スタックから使用済みの2つの数字を削除してから,①の答えをスタックに入れる.
③結果として,最後の答えはスタックの先頭にある
使っていいのはinput,print,while,if,len,str
な機能を実装中に以下のエラーメッセージが発生しました。正しく動かすにはどうしたら良いか教えてください。

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

stack =shiki[n] + stack TypeError: can only concatenate str (not "list") to str

該当のソースコード

ソースコード shiki =input() stack =[] a=len(shiki) n=0 while n<=a: if shiki[n] == "+": register2 = int(stack[0]) register1 = int(stack[1]) kotae = register1 + register2 stack = stack[2:] stack = str(kotae) + stack else: stack = shiki[n] + stack kotae = stack[0] print(kotae)

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

hentaiman

2020/11/18 08:46

面倒くさそうなコードに見えますが、何か特殊な指定(使用する命令(標準ライブラリ)の指定など)のある課題でしょうか?
eguti

2020/11/18 08:58

はい!stackの勉強課題です。初心者なので特殊な指定がわかりませんが、条件は書いてある通りです。やっていて詰まったので質問しました。
hentaiman

2020/11/18 09:04 編集

じゃあ自力で作ったコードって事ですね 課題の制限が曖昧過ぎて使って良いのかは分かりませんが、ポーランド記法での計算を作るならpush(pythonではappend)とpopを利用するのが良いですよ can only concatenate strはそのまま検索すればエラーの説明してくれてるサイトたくさん見つかるのでとりあえず検索してはどうでしょうか?
eguti

2020/11/18 13:04

動かすことができました。教えて頂きありがとうございました。
guest

回答2

0

ええと、リストの任意の位置に要素を挿入するには通常insertを使います。先頭(位置0)に追加するなら、stack.insert(0, shiki[n])ですね。

ただ、今回はinsertが使えない縛りのようなので、スライスを使って同じ結果を得てください。stack[0:0] = shiki[n]です。足し算のほうの処理も同様です。

このほかにも、

  • 「2 1 + のような式の答え」を得るには、空白を読み飛ばす処理が必要(「21+」みたいな入力なら不要)
  • nを増やす処理が書いてない
  • whileによる繰り返しの境界条件が間違っている

あたりの問題をご自分で解決してください。

投稿2020/11/18 10:31

Daregada

総合スコア11990

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

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

eguti

2020/11/18 13:07

動かすことができまいした。答えて頂き本当にありがとうございます。
guest

0

ベストアンサー

だいたいよさそうですが、いくつか問題があります。

■ エラーになった部分。
スタックの先頭にデータを足す処理は、リストどうしにしないといけません。
【その1】

python

1 stack = str(kotae) + stack

python

1 stack = [str(kotae)] + stack

【その2】

python

1 stack = shiki[n] + stack

python

1 stack = [shiki[n]] + stack

■ 入力をリストにしなければなりません
どのように入力するかわかりませんが、"13 4 +"のように空白で区切るのであれば、空白で分割してリストにします。

python

1shiki =input().split((' '))

■ while の中のnのインクリメントが抜けています。
whileループの最後に以下の行を追加

python

1 n += 1

■ ループの条件が間違えています。

nは0 始まりなので、whileの判定は n<=aではなくn<aです。

これで動くようになるのではないかと思いますよ。


おまけ

pythonのリストの先頭から値を出し入れするのはやりにくいのです。
そうでなくて、一番後ろからということであれば、popとappendを使うことでスタックらしい処理にできます。
whileの部分だけ書くとこんな感じです。

python

1while n<a: 2 if shiki[n] == "+": 3 register2 = int(stack.pop()) 4 register1 = int(stack.pop()) 5 kotae = register1 + register2 6 7 stack.append(str(kotae)) 8 9 else: 10 stack.append(shiki[n]) 11 12 n += 1

※ 通常stackではpopと対になるのはpushですが、pythonではappendを使います。

投稿2020/11/18 10:40

編集2020/11/19 10:00
TakaiY

総合スコア13792

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

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

eguti

2020/11/18 13:05

丁寧に回答してくださりありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問