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

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

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

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

Q&A

解決済

1回答

553閲覧

素数判定プログラムで途中までしか結果が表示されません

Rinno

総合スコア7

Python

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

0グッド

1クリップ

投稿2019/09/19 11:36

前提・実現したいこと

python3でnのn乗の和を生成し、それらが素数であるかを調べています

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

以下のコードで upper を31以上にすると、31以上の結果がspyderのコンソール画面に表示されません 30までの結果は出力されます。

該当のソースコード

python3

1import time 2import math 3 4 5not_prime = [0, 2, 4, 5, 6, 8] 6 7total = 0 8lower = 1 9upper = 30 10 11 12start = time.time() #時間の測定 13 14 15for n in range(lower,upper): 16 total += pow(n,n) 17 num_array = list(map(int, str(total))) #各位の和 18 19 if total % 10 in not_prime: #2、5の倍数を除外 20 print(total) 21 continue 22 23 if sum(num_array) % 3 == 0: #3の倍数を除外 24 print(total) 25 continue 26 27 for i in range(3, int(math.sqrt(total)) ,2): #√nまで奇数で割っていく 28 if total % i == 0: 29 print(total) 30 break 31 else: 32 print(str(total) + " 素数") 33 34 35total_time = time.time() - start 36print("かかった時間: {:.4f} 秒".format(total_time)) 37

試したこと

print関数に flush = True を加えてみましたが変わりませんでした

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

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

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

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

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

guest

回答1

0

ベストアンサー

時間がかかってるだけだと思います。
条件付きブレークポイントを置いてデバッグしてみましたが、数分かけても動き続けていました。

投稿2019/09/19 11:58

Zuishin

総合スコア28660

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

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

Zuishin

2019/09/19 12:01

int(math.sqrt(total)) は 14439266374844122398720 になります。
Rinno

2019/09/20 08:36

ありがとうございます。時間がかかっているだけだったんですね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問