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

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

新規登録して質問してみよう
ただいま回答率
85.46%
コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Q&A

解決済

1回答

496閲覧

最後まで実行されません

退会済みユーザー

退会済みユーザー

総合スコア0

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

0グッド

1クリップ

投稿2021/01/21 06:19

編集2021/01/24 01:50

このようにコードをかいたのですが、実行するとi=56691で止まってしまいます。なぜでしょうか?
下から4行目のc(i)を3など普通の整数にすると最後まで実行されました。
よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

コラッツの問題ですかねこれ。

計算途中のxの値が増大してint型の正の最大値越えて符号反転してるんじゃないでしょうか。
x, counterに64bit整数型使えばi=60000までなら走り切りますよ。それ以降は知りませんけど。

投稿2021/01/21 07:30

Munosuke222

総合スコア158

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

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

退会済みユーザー

退会済みユーザー

2021/01/21 08:12

回答ありがとうございます。無事に実行されました。 ちなみに、上から2行目でMAXを60000と定義しているのですが、いくつくらいまでなら計算できるのでしょうか? 実行環境によって異なると思うのですが、なにかコマンドを打てば分かるのでしょうか?それともひたすら実行して動かなくなるまで探すのでしょうか?
Munosuke222

2021/01/21 08:37

全然詳しくないからわかんないけど、たぶん初期値から見積もる方法はないんじゃないかな。 どれくらい途中の数が増大するか初期値から見積もれたらそれはもうコラッツの問題が解けたのと一緒だと思うし(コラッツの問題って要するに際限なく増大する初期値が存在するかってどうかってことだろうし) 逐一やってみるしかないんじゃないかな。
退会済みユーザー

退会済みユーザー

2021/01/21 08:51

なるほど、ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問