π
<-
Chat plein-écran
[^]

[Résolu] Algo calcul nombre de combinaisons

Discussions diverses, débats, sondages, parler de tout et de rien... mais en restant plutôt sérieux.

[Résolu] Algo calcul nombre de combinaisons

Message non lude Persalteas » 25 Jan 2016, 09:56

Salut,

Vous connaissez peut être la formule du nombre de combinaisons:
Si je veux calculer les nombre de façons de tirer 3 éléments dans 10 éléments, je fais:

$mathjax$\bigl(\begin{smallmatrix}
10\\
3
\end{smallmatrix}\bigr) = \frac{10!}{3! (10-3)!}$mathjax$


Bon, il se trouve que j'ai besoin non pas 10 éléments mais de 1000.
On a tous remarqué que les calculatrices ne dépassent pas le calcul de 69! (70! dépasse 10^100), et pourtant, les TI et Casio sont capables de retourner sans problème le nombre de combinaisons dans 1000 éléments, alors qu'il me semblait avoir besoin d'utiliser un 1000! ...

J'imagine donc qu'en mémoire, elle repère direct le
$mathjax$\frac{1000!}{ (997)!}$mathjax$
et donc ne calcule que 1000*999*998.
Est-ce que vous connaissez plus en détail avec quel algo ce calcul est réalisé ?
Avatar de l’utilisateur
PersalteasMembre UPECS
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Prochain niv.: 6.2%
 
Messages: 2337
Images: 113
Inscription: 04 Fév 2010, 00:00
Localisation: Evry (France)
Genre: Homme
Calculatrice(s):
MyCalcs profile
Classe: PhD candidate, Bioinformatics

Re: Algo calcul nombre de combinaisons

Message non lude Bisam » 25 Jan 2016, 11:53

Euh, ben, c'est facile, il suffit de ne pas utiliser cette formule avec les factorielles... parce qu'elle est pourrie au niveau de la complexité algorithmique.

Le mieux est de remarquer que
$mathjax$\displaystyle \binom{n}{p}=\frac{1}{p!}\prod_{k=n-p+1}^{n}k$mathjax$
.
On est ramené à effectuer
$mathjax$2p$mathjax$
produits et 1 division à la fin.
On peut encore diminuer le nombre de calculs en remarquant que
$mathjax$\binom{n}{p}=\binom{n}{n-p}$mathjax$
et en choisissant la plus petite des 2 valeurs entre
$mathjax$p$mathjax$
et
$mathjax$n-p$mathjax$
.

On peut alors faire le calcul ainsi :
Code: Tout sélectionner
def binom(n, p):
    """Renvoie le coefficient binomial C(n,p)"""
    num = denom = 1
    if p > n-p:
        p = n-p
    for i in range(1, p+1):
        num *= n-i+1
        denom *= i
    return num // denom
Avatar de l’utilisateur
BisamAdmin
Niveau 15: CC (Chevalier des Calculatrices)
Niveau 15: CC (Chevalier des Calculatrices)
Prochain niv.: 69.6%
 
Messages: 5665
Inscription: 11 Mar 2008, 00:00
Localisation: Lyon
Genre: Homme
Calculatrice(s):
MyCalcs profile

Re: Algo calcul nombre de combinaisons

Message non lude Persalteas » 26 Jan 2016, 08:11

C'est parfait !

Merci beaucoup !
Avatar de l’utilisateur
PersalteasMembre UPECS
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Prochain niv.: 6.2%
 
Messages: 2337
Images: 113
Inscription: 04 Fév 2010, 00:00
Localisation: Evry (France)
Genre: Homme
Calculatrice(s):
MyCalcs profile
Classe: PhD candidate, Bioinformatics


Retourner vers Autres discussions

Qui est en ligne

Utilisateurs parcourant ce forum: Aucun utilisateur enregistré et 60 invités

-
Rechercher
-
Social TI-Planet
-
Sujets à la une
Comparaisons des meilleurs prix pour acheter sa calculatrice !
Aidez la communauté à documenter les révisions matérielles en listant vos calculatrices graphiques !
Phi NumWorks jailbreak
123
-
Faire un don / Premium
Pour plus de concours, de lots, de tests, nous aider à payer le serveur et les domaines...
Faire un don
Découvrez les avantages d'un compte donateur !
JoinRejoignez the donors and/or premium!les donateurs et/ou premium !


Partenaires et pub
Notre partenaire Jarrety Calculatrices à acheter chez Calcuso
-
Stats.
1186 utilisateurs:
>1148 invités
>33 membres
>5 robots
Record simultané (sur 6 mois):
6892 utilisateurs (le 07/06/2017)
-
Autres sites intéressants
Texas Instruments Education
Global | France
 (English / Français)
Banque de programmes TI
ticalc.org
 (English)
La communauté TI-82
tout82.free.fr
 (Français)