kakashi-blog・カカシブログ・

Python備忘録を書きドローンやバイクなど好きな事で生きて行こうとしているブログ

python プログラミング 未分類

カプレカ数をpythonで求める

投稿日:

カプレカ数とは

まず6174を例にとってみます。

’6’、’1’、’7’、’4’と桁を関係なく数字をバラバラにします。

その数字の並び替えを[最大]と[最小]になるように並び替えます。

・最大 7641(3番、1番、4番、2番に並び替え)

・最小 1467(2番、4番、1番、3番に並び替え)

その後 [最大]ー[最小]=元の数字 になるものがカプレカ数となります。

7641ー1467=6174

※4桁はこの数字以外は存在しません。

 考え方は実にシンプル


退屈なことはPythonにやらせよう 第2版 ―ノンプログラマーにもできる自動化処理プログラミング

一個ずつ計算して証明してみる

めんどくさすぎなのでpythonで書いてみます。

(学習題材としては良い課題になるのではないかと)


import copy

num=0

while num<=99999999999999999999: #20桁求めてみる
    n=[]

    for i in range(len(str(num))):
        n.append(str(num)[i])
    
    n.sort()             #並び替え(小さい順)
    s=copy.copy(n)
    n.sort(reverse=True) #並び替え(大きい順)
    s=(''.join(s))       #リスト内の並び替えた数字を1つの数列へ
    n=(''.join(n))       #リスト内の並び替えた数字を1つの数列へ
    kap=int(n)-int(s)    #最大ー最小
    
    if kap==num:         #カプレカ数なのか判断
        print(num)
    num+=1

簡単に書いてみた。

出力結果

0
495
6174
549945
631764

やけに少ないと思った方もいると思います。

もちろん全てではないです。

数秒で5個は出てきますが、そのあとは時間がかかりすぎるので途中でやめました。
5分回しても6個目が出てこない、20桁なんて夢でした・・・

時間をかければでますが、何か別の法則で求めないと無理そうですね。

需要はなさそうだけど備忘録として保存しておきます。

専門家ではないので、何か誤りなど見つけた方ご指摘いただけると助かります。

-python, プログラミング, 未分類
-, ,

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

ネム(XEM)保有で Symbol(XYM)ゲット!価格は?

現状 2021.3.12にスナップショットが行われ、symbol(XYM)(以後「ジム」)の配布を待っている状態。 私はコインチェックにて、ネム(XEM)(以後「ゼム」)をスナップショット以前から約5 …

3Dプリンター用のデータの作り方(初心者向けFusion 360の使い方)

   3Dプリンターを購入し、作りたい物が作れるようになったので、3Dプリンターで使える3Dデータ(STLデータ)の作り方を解説します。ソフトは無料の物を使用します。   簡単!きれいな造形です!とう …

仮想通貨マイニング、電気代は実際いくらかかるのか

現在暴落中の仮想通貨ですが、先週くらいまではイケイケでした。 そんな中マイニングを始めたわけですが、儲かるのかどうなのか、 ちゃんと計算してみました。   基本的な収支の考え    マイニング収益 ー …

サラリーマンが株取引で利益、損益を出した時の確定申告のやり方(初めての方)

  一般的にサラリーマンはあまり確定申告をすることはありませんが、今回はそんなサラリーマンが株取引で利益、損益をだした時に確定申告をする事を想定して記事を書きます。   まず株の取引きをする場合、通常 …

ソフトバンクからワイモバイルにiPhoneで乗り換える方法(MNP)

現在iPhone7を使用中、番号そのまま(MNP)ソフトバンクからワイモバイルに乗り換えたので自分なりにまとめます。   何から始めればいいのか 結構大事なことだけど、あまり書かれていないので書いてお …