IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Mathématiques Discussion :

Fonction récursive à deux arguments


Sujet :

Mathématiques

  1. #1
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut Fonction récursive à deux arguments
    Bonjour
    J'ai une fonction récursive toute simple
    f(x,y) = f(x-1,y) + f(x, y-1)
    f(x, 0) = f(0, y) = 1
    Je pense que cette fonction doit être connue et porter un nom mais je l'ignore.
    J'aurais voulu connaître son nom, et aussi une méthode rapide de calcul, par exemple une méthode pour la dérécursiver car je n'en ai pas trouvé .
    Tout ce que j'ai trouvé est
    Nom : my_somme.jpg
Affichages : 151
Taille : 1,4 Ko
    ce qui ne me mène pas très loin par rapport à la première définition !
    J'obtiens en C
    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    #define MAX 10000
    unsigned long long int val[MAX][MAX];
    unsigned long long int f(int x, int y)
    {
        if (val[x][y] == 0)
        {
            unsigned long long int tt = 0;
            for (int i = 0; i <= x; i++)
            {
                if (y == 0)
                    tt = 1;
                else
                    tt += f(i, y - 1)) ;
            }
            val[x][y] = tt;
        }
        return val[x][y];
    }
    La mémoïsation c'est bien gentil mais quand on a de très grandes valeurs on arrive vite aux limites des systèmes.
    Merci pour vos conseils et indications !
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  2. #2
    Expert éminent sénior Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 243
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 243
    Points : 13 459
    Points
    13 459
    Par défaut
    Bonjour

    Déjà, ça part mal. Je ne suis pas d'accord avec ta formule (écrite en latex). Il manque forcément un "+1" quelque part.

    Ensuite, la formule fait évidemment pensé au triangle de pascal. Et c'est sans surprise que j'arrive à la formule suivante :

    Formule mathématique

    Il te reste à discuter si x>y ou x<y pour savoir lequel touche le sol le premier.

    Bonne chance
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

  3. #3
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Merci de ta réponse.
    La formule (Libre Office formule) est sans doute fausse pour le +1 mais le code C est correct, et effectivement le triangle de Pascal s'invite dans la danse.
    Pour x et y, avec la mémoïsation j'appelle toujours avec x plus petit que y, mais ça ne suffit pas pour accélérer les calculs.
    Je continue ...
    PS je ne connaissais pas la balise spécifique C !
    A quand la balise Prolog
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  4. #4
    Expert éminent sénior Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 243
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 243
    Points : 13 459
    Points
    13 459
    Par défaut
    Pour la mémoïsation, c'est d'accord. Mais reste un peu plus au niveau théorique. Je ne suis pas convaincu que tu ne puisses pas tout résoudre théoriquement avant de faire le code. Pour n=4, les paramètres vont de (x-4;y) à (x;y-4) en passant par (x-2;y-2), par exemple. Donc il arrivera des cas où le second paramètre sera plus petit que le premier.C'est ça qu'il faut régler pour finir le calcul.
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

  5. #5
    Rédacteur/Modérateur

    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Décembre 2013
    Messages
    4 057
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2013
    Messages : 4 057
    Points : 9 396
    Points
    9 396
    Par défaut
    Sauf erreur, f(x,y)=fact(x+y)/( fact(x)*fact(y) ) où fact() est la fonction factorielle.
    Ca devrait permettre une implémentation permettant de calculer f(x,y) en direct, sans passer par les calculs de tous les éléments précédents.
    Par contre, il faut certainement simplifier les calculs avant de faire la division :
    Par exemple, pour calculer f(1000,4), si on calcule fact(1004) ... puis qu'on divise par fact(1000) et par fact(4), on va passer par des nombres très grands (dépassement de capacité ...) pour arriver à un calcul simple en fait.
    N'oubliez pas le bouton Résolu si vous avez obtenu une réponse à votre question.

  6. #6
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Merci de vos contributions et désolé pour la réponse tardive.
    J'ai réussi à vérifier gràce au triangle de Pascal que
    Nom : my_fonc.jpg
Affichages : 104
Taille : 804 octets
    Je n'ai plus qu'à abandonner le C pour faire mes calculs en Haskell, j'aurais moins de problèmes ...
    Merci.
    PS C'est exactement ce que tu as écrit tbc92 mais je voulais trouver tout seul
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  7. #7
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Fin de partie
    Même en Haskell, ça ne fonctionnera pas.
    Un des calculs me donne un résultat de 587 chiffres après un calcul de 21,5 secondes ! (et ce n'est qu'un résultat intermédiaire).
    Je vais changer de méthode pour résoudre le problème !
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  8. #8
    Rédacteur/Modérateur

    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Décembre 2013
    Messages
    4 057
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2013
    Messages : 4 057
    Points : 9 396
    Points
    9 396
    Par défaut
    Si le calcule passe par les calculs de fact(x), fact(y) et fact(x+y), effectivement, ces résultats intermédiaires vont donner des nombres très grands.

    Mais ça revient en fait à cette boucle :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    si y>x alors      // On inverse les 2 termes pour avoir une boucle aussi courte que possible.
       y0=y
       y=x
       x=y0
    fin
     
    resu = 1
    pour i = 1 a y
      resu=resu*(x+y)/i
    fin
    renvoyer resu
    Ici, aucun résultat intermédiaire avec des nombres nettement plus grands que le résultat final.
    N'oubliez pas le bouton Résolu si vous avez obtenu une réponse à votre question.

  9. #9
    Expert éminent sénior Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 243
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 243
    Points : 13 459
    Points
    13 459
    Par défaut
    Peut-on avoir un ordre de grandeur de x et y ?

    Python donne instantanément f(100;100) = 90548514656103281165404177077484163874504589675413336841320

    Si tu es bien en-dessus de ces valeurs, tu rentres dans le domaine de la cryptographie, où il est normal que l'ordinateur soit dépassé. Il faut marcher sur des œufs.

    As-tu lu cet article pour avoir une approximation (clic ici) de f(x,y) ?
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

  10. #10
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    C'est f(333193, 156) qui a pris ce temps sur Haskell, j'ai vérifié f(100,100) est aussi instantané sur Haskell.
    Ce calcul de f(333193, 156) est un calcul intermédiaire, j'en ai une centaine comme ça à faire, si je continues avec le même raisonnement, c'est pour ça que je dis que je dois changer absolument de concept de résolution du problème.
    Pour la petite histoire, je tente de résoudre un problème "moyen" sur Codingame, alors je me dis qu'il y a forcément une solution 10000 fois plus rapide (la programmation dynamique par exemple).
    Ce que c'est que d'avoir la tête dans le sac.
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Fonction récursive et deux types de retour
    Par dtom99 dans le forum Windows Forms
    Réponses: 15
    Dernier message: 03/02/2010, 20h30
  2. fonctions récursives et passage d'arguments
    Par Jasmine80 dans le forum Langage
    Réponses: 11
    Dernier message: 05/12/2008, 10h26
  3. dégriser un champ : deux arguments dans la fonction
    Par fripette dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 09/06/2008, 18h20
  4. Réponses: 4
    Dernier message: 18/09/2007, 10h46
  5. fonction à deux arguments
    Par bobic dans le forum ASP
    Réponses: 3
    Dernier message: 26/04/2006, 22h05

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo