質問するログイン新規登録
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

2回答

750閲覧

ある数より小さい「互いに素」である数の総量を調べたい

antino

総合スコア15

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2022/04/11 00:13

編集2022/04/11 00:14

0

0

ある数より小さい互いに素である数を調べたいです。

例えば 10の場合 [1,3,5,7,9]が互いに素なので、総量は5です。
[2,4,6,8]はお互い2で割り切れてしまうので互いに袖はありません。

途中までのプログラムを↓のように書いています。

def coPrime(): x=100 count=0 primes=[] for i in range(1,x): if(i==1): count+=1 if(x%i!=0): primes.append(i) print("i is "+str(i)) count+=1 print("count is "+ str(count)) coPrime()

既に出てきた素数をprimesに加えて、iが primesの数で割れれば 互いに素となると思うのですが、ここから進め方がわからず、ご助言いただきたいです。

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

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

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

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

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

5ugarVVatch1ng

2022/04/11 01:00 編集

重箱の隅をつつくことを言いますが > 例えば 10の場合 [1,3,5,7,9]が互いに素なので 10と5は5で割り切れるので互いに素ではないと思います。
TakaiY

2022/04/11 09:57

「ある数より小さい互いに素である数」とはどのような数ですか? [1,3,5,7,9]だと、3と9は共通員数3を持つし、ここに[1,3,5,7] としても、[1,5,7,9]としてもよさそうだし、さらにここに 2,4,8の何れかを入れても「1以外に共通員数を持たない数の組」ができるし。
guest

回答2

0

例えば 10の場合 [1,3,5,7,9]が互いに素なので、総量は5です

39 は互いに素ではないので 10 未満の場合は [1, 2, 3, 5, 7] になるのではないでしょうか(総量は 5 ですが)。

python

1from math import gcd 2 3n = 10 4m = range(1, n) 5[j for i, j in enumerate(m) if not any(gcd(j,t)!=1 for t in m[:i])] 6 7# 8[1, 2, 3, 5, 7]

投稿2022/04/11 02:53

melian

総合スコア21341

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

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

hoshi-takanori

2022/04/11 04:56

問題文があいまいではありますが、「互いに素」は 2 つの数の関係なので、ある数 (例えば 10) と互いに素である数の集合と解釈するのが妥当では。「結果集合から任意の 2 数を取り出したときに互いに素である」という条件とは読めないので。また、そう解釈した場合、答えが一意に定まらないような (例えば 3 と 9 が互いに素でないときに 3 を取り除いてもいいわけで。)
guest

0

iが primesの数で割れれば 互いに素となると思うのですが

ならないと思います。

ある数より小さい互いに素である数を調べたいです。

  1. 「互いに素 判定」でググる
  2. 1.で判明した判定方法に利用できそうなメソッドがPythonに存在するかググる
  3. 1から10まで1.2.を利用してロジックを書く

投稿2022/04/11 00:59

5ugarVVatch1ng

総合スコア358

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問