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

Python Discussion :

Suite, seuil et suite auxiliaire ?


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2022
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2022
    Messages : 4
    Par défaut Suite, seuil et suite auxiliaire ?
    Bonjour à tous,
    Je suis un débutant et je cherche à résoudre le problème suivant qui m'a été posé:
    On considère la suite (un) définie par :
    un+1 = un + (2/un)
    u0 = 2
    On cherche à déterminer la plus petite valeur de n telle que la différence (en valeur absolue) entre 2 valeurs consécutives
    de la suite (un), c’est-à-dire |un+1 − un|, est inférieure à epsilon=0.01
    Je dois écrire un programme pour déterminer la valeur de n.
    Je pensais (comme indiqué dans le titre) utiliser une suite auxiliaire (vn) définie par : vn= |un+1 − un| pour ensuite voir quand vn est inférieure à epsilon. Or mon code ne fonctionne pas. Soit mon idée est nulle soit mon code est nul, ce qui est plus probable. Qu'en pensez-vous? Merci.
    Voici le code : j'ai défini (vn) et le seuil mais je ne sais pas définir (un)
    Nom : Seuil.JPG
Affichages : 981
Taille : 11,9 Ko

  2. #2
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par MJ951 Voir le message
    Soit mon idée est nulle soit mon code est nul, ce qui est plus probable. Qu'en pensez-vous?
    Dans tous les langages de programmation du monde, u-u vaut 0 (je crois même que c'est un des fondements de la soustraction telle qu'on l'apprend au primaire). A partir de là, écrire v=abs(u-u) ne peut pas fonctionner (d'autant plus que "u" est vu par Python comme une variable alors que dans ton code cette variable n'existe pas).

    L'idée de départ est bonne mais pourquoi définir vn? Une boucle dans laquelle tu mémorise le Un courant avant de calculer Un+1 (qui devient le nouvel Un)
    Et si le Un nouvellement calculé "moins" le Un mémorisé juste avant est inférieur à epsilon alors tu peux quitter ta boucle.

    Et ici on poste les codes. En plus d'être mentionné dans les règles c'est plus lisible, ça ne provoque pas d'ulcération aux doigts et surtout ça nous permet de les copier/coller pour les tester.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2022
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2022
    Messages : 4
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    n=0
    u0=2
    u1=3
    while abs(u1-u0)>=0.01:
        n=n+1
        u0=u1
        u1=u0+(2/u0)
    print(n)

    Voici ce que j'ai fait. Ça m'a l'air de fonctionner je trouve 9997. Ce code vous semble-t-il bien ?

  4. #4
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par MJ951 Voir le message
    je trouve 9997
    C'est aussi ce que j'avais trouvé de mon côté.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2022
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2022
    Messages : 4
    Par défaut
    Merci pour votre aide c'est super comme site bonne soirée

  6. #6
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 736
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 736
    Par défaut
    Citation Envoyé par MJ951 Voir le message
    Ce code vous semble-t-il bien ?
    S'il fonctionne... et qu'il traduit bien l'algorithme qui est dans votre tête avec le python que vous connaissez.
    Pour le reste, je suis surpris par votre insistance à utiliser abs alors que un+1 - un est positif.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  7. #7
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2022
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2022
    Messages : 4
    Par défaut
    Citation Envoyé par wiztricks Voir le message
    Pour le reste, je suis surpris par votre insistance à utiliser abs
    C'est parce que c'est formulé ainsi dans l'énoncé du devoir. Mais vous avez raison j'aurais dû m'en rendre compte direct

  8. #8
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 736
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 736
    Par défaut
    Citation Envoyé par MJ951 Voir le message
    C'est parce que c'est formulé ainsi dans l'énoncé du devoir. Mais vous avez raison j'aurais dû m'en rendre compte direct
    Sinon, avec le Python que je connais, j'écrirais cela:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    n = 0
    u = 2
     
    while True:
        v, u = u, u + 2/u
        n += 1
        if (u - v) <= 0.01:
            break
     
    print(n)
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 16/12/2019, 19h48
  2. Pb BDE suite a passage en Windows 2000 pro
    Par ARIF dans le forum Paradox
    Réponses: 4
    Dernier message: 18/11/2002, 11h39

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