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

Discussion :

Langage le plus rapide : python ou C ?

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 5
    Par défaut Langage le plus rapide : python ou C ?
    Bonjour.

    En fait je me pose une question, j'ai vu dans une vidéo que C était soit disons X fois plus rapide que python, mais avec mes minces connaissances, j'ai écrit un programme qui teste la conjecture de syracuse, dans chacun de ces 2 langages, de 1 jusqu'à 50.000, et C est totalement largué, le prog en python finit largement avant, plus de 50 secondes avant le prog en C.

    Donc C est-il vraiment plus rapide ? Si oui faut m'expliquer lol.

  2. #2
    Responsable Qt & Livres


    Avatar de dourouc05
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2008
    Messages
    26 772
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2008
    Messages : 26 772
    Par défaut


    Si tu codes comme un pied en C, Python risque d'être plus rapide. L'inverse est aussi vrai. La vraie différence, c'est que tu peux optimiser autant que tu veux en C : en Python, tu devras sortir du langage pour atteindre le dernier degré de performance.

    Dans https://julialang.org/benchmarks/ (temps de calcul normalisés par rapport au C), on voit que, sur les problèmes testés, Python arrive une fois à peu près au niveau de C (de par l'utilisation d'une bibliothèque écrite en Fortran pour la multiplication matricielle), mais est sinon largué.

    Donne les deux codes que tu as utilisés pour tes tests : des gens plus avertis pourraient remarquer des problèmes dans le code (ne fût-ce qu'un malloc/free à chaque itération, ça tue la performance en moins de deux…).
    Vous souhaitez participer aux rubriques Qt (tutoriels, FAQ, traductions) ou HPC ? Contactez-moi par MP.

    Créer des applications graphiques en Python avec PyQt5
    Créer des applications avec Qt 5.

    Pas de question d'ordre technique par MP !

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 5
    Par défaut
    Voici mon code en python :

    Code Python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    def syracuse(n):
        print(n)
        while n != 1:
            if n % 2 == 0:
                n = n / 2
            else:
                n = 3 * n + 1
            print(int(n))
     
    nombre = 1
    while nombre < 50001:
        syracuse(nombre)
        nombre = nombre + 1
        print("*******************************************************************************************")
        print()



    Voici mon code 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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    #include <stdio.h>
    #include <stdlib.h>
     
    void syracuse(n) {
        printf("%d\n", n);
        while(n!=1) {
            if (n % 2 == 0) {
                n = n / 2;
            }
            else {
                n = 3 * n + 1;
            }
                printf("%d\n", n);
                }
    }
     
    int main()
    {
        long nombre = 1;
        while (nombre < 50001) {
        syracuse(nombre);
        nombre++;
        printf("**************************************************************\n");
        }
     
        printf("\n");
        return 0;
    }

    Je suis débutant, alors c'est très possible que les codes soient très très améliorables lol.

  4. #4
    Responsable Qt & Livres


    Avatar de dourouc05
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2008
    Messages
    26 772
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2008
    Messages : 26 772
    Par défaut
    Que se passe-t-il si tu retires les instructions d'affichage dans la boucle de calcul ? Je suppose que Python n'affiche pas le texte que tu lui demandes immédiatement, mais groupe plusieurs appels, contrairement à l'implémentation de la bibliothèque standard C.
    Vous souhaitez participer aux rubriques Qt (tutoriels, FAQ, traductions) ou HPC ? Contactez-moi par MP.

    Créer des applications graphiques en Python avec PyQt5
    Créer des applications avec Qt 5.

    Pas de question d'ordre technique par MP !

  5. #5
    Membre chevronné
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    351
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 351
    Par défaut
    Bonsoir,

    Dans le code C on doit pouvoir remplacer :
    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    if (n % 2 == 0) {
      n = n / 2;
    }
    else {
      n = 3 * n + 1;
    }

    par :
    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    n = (n & 1) ? (3*n + 1) : (n / 2);

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 5
    Par défaut
    Canvas : J'ai essayé avec la ligne de code que tu dis mais j'ai une erreur.

    Cette erreur : |22|error: expected declaration or statement at end of input|





    dourouc05 :Le problème c'est que sans instruction d'affichage je vois rien défiler et ça complique la comparaison.

Discussions similaires

  1. Réponses: 25
    Dernier message: 10/05/2015, 09h36
  2. Réponses: 11
    Dernier message: 10/09/2012, 04h08
  3. Langage le plus rapide pour une application web ?
    Par beninsky dans le forum Débuter
    Réponses: 2
    Dernier message: 04/05/2010, 21h29
  4. Python plus rapide que l'Assembleur ?
    Par le pythonien dans le forum x86 16-bits
    Réponses: 8
    Dernier message: 17/08/2009, 21h57
  5. [Info] Un python plus rapide que le C
    Par anthyme dans le forum Interfaçage autre langage
    Réponses: 2
    Dernier message: 21/02/2008, 18h18

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