Apprendre Maple Index du Forum Apprendre Maple
Site dédié au logiciel de calcul formel Maple
 
  Page d'accueilPage d'accueil   FAQFAQ    RechercherRechercher    Liste des MembresListe des Membres    Groupes d'utilisateursGroupes d'utilisateurs 
S'enregistrerS'enregistrer    ProfilProfil   Se connecter pour vérifier ses messages privésSe connecter pour vérifier ses messages privés   ConnexionConnexion 

Somme des factorielles des chiffres

 
Poster un nouveau sujet   Répondre au sujet    Apprendre Maple Index du Forum -> Autres questions
Voir le sujet précédent :: Voir le sujet suivant  
Auteur Message
zozo



Inscrit le: 03 Jan 2013
Messages: 125

MessagePosté le: 27 Sep 2019 8:40    Sujet du message: Somme des factorielles des chiffres Répondre en citant

Bonjour, pourriez-vous m'aider à écrire un programme qui cherche tous les entiers N égaux à la somme des factorielles de leurs chiffres (en base 10).

Donc tels que N=a_n.a_(n-1)....a_1.a_0=Sum (a_i !,i=0..n) (en système décimal).

Par exemple N=145 est solution, car 1 ! + 4 ! + 5 ! = 1 + 24 + 120 = 145.

J'ai cherché mais je sèche pas mal.

Merci d'avance.
Revenir en haut de page
Voir le profil de l'utilisateur Envoyer un message privé
ALS



Inscrit le: 11 Sep 2006
Messages: 647

MessagePosté le: 27 Sep 2019 9:11    Sujet du message: Répondre en citant

Bonjour zozo.

Un tel nombre s'appelle un factorion.

La procédure facDigits donne pour résultat la somme des factorielles des chiffres de l'entier positif n (base 10) :
la liste [L] contient les chiffres de n.

Code:

> facDigits:=proc(n::posint)
   local L,n1,q,i,k,l;
   n1:=n; L:=NULL;  i:=floor(log10(n1))+1: l:=i:
   while n1>0 do
     i:=i-1:
     q:=floor(n1/10^i):
     n1:=n1-q*10^i:
     L:=L,q
   end do:
   if nops([L])<l then
    for k from 1+nops([L]) to l do L:=L,0 end do
   end if:
   convert(map(x->x!,[L]),`+`)
   end proc:

> facDigits(23074);  #  2!+3!+0!+7!+4!=5073
                              5073



Recherche des factorions, solutions du problème posé inférieures à 100000 :

Code:

> SOL:=NULL: maxi:=10^5: k:=0:
> while k<maxi do
       k:=k+1: 
       if k=facDigits(k) then SOL:=SOL,k: print(k," est solution") end if
    end do:
                       1, " est solution"
                       2, " est solution"
                      145, " est solution"
                     40585, " est solution"
> [SOL];
                       [1, 2, 145, 40585]



A plus tard sur le forum.
Revenir en haut de page
Voir le profil de l'utilisateur Envoyer un message privé
Montrer les messages depuis:   
Poster un nouveau sujet   Répondre au sujet    Apprendre Maple Index du Forum -> Autres questions Toutes les heures sont au format GMT + 2 Heures
Page 1 sur 1

 
Sauter vers:  
Vous ne pouvez pas poster de nouveaux sujets dans ce forum
Vous ne pouvez pas répondre aux sujets dans ce forum
Vous ne pouvez pas éditer vos messages dans ce forum
Vous ne pouvez pas supprimer vos messages dans ce forum
Vous ne pouvez pas voter dans les sondages de ce forum


phpBB

Développé par phpBB © 2001, 2006 phpBB Group
Traduction par : phpBB-fr.com


Apprendre Maple - ©  - Alain Le Stang - Navigation optimisée pour une résolution 1024 x 768.