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

C++ Discussion :

Résolution du crible d’Ératosthène


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2018
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2018
    Messages : 2
    Par défaut Résolution du crible d’Ératosthène
    bonjour
    je veux afficher l'ensemble des nombre premier inférieur à un entier n par le Crible d’Ératosthène et j'ai un problème quand n dépasse 15 pouvez vous m'aider voila mon code:
    merci d'avance

    Code : 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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    #include<iostream>
    #include<math.h>
    using namespace std;
    // je cree un tableaux dynamique 
    int* tab(const int taille)
    {
    	int* tab = new int[taille];
    	return tab;
    }
     
    int main()
    {
    	int i, j,n,compteur=1;
    	int k = 0;
    	cout << "saisir le reelle n:  ";
    	cin >> n;
    	int * tabl = tab(n);
    	for (i = 0; i < n; i++)
    		tabl[i] = i;
    	for(i=2;i<sqrt(n);i++)
    	{ 
    		for (j = i+1; j < n; j++)
    		{
    			if (i != j)
    			{
    				if (j%tabl[i] == 0)
    				{
    					compteur=compteur+1;
    					tabl[j] = 1;
     
    				}
    			}
    		}
    	}
    	int *newtab = tab(n - compteur);
    	for (i = 1; i < n; i++)
    	{
    		if (tabl[i] != 1)
    		{
    			newtab[k] = tabl[i];
    			k++;
    		}
     
    	}
    	cout << "\nles nombres premier sont au nombre de "<<n-compteur<<"\n";
    	for (i = 0; i < (n - compteur); i++)
    	{
    		cout << newtab[i];
    		//system("pause");
    	}
     
    	cout << "\n\n";
     
     
    	return 0;
    }

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Network game programmer
    Inscrit en
    Juin 2010
    Messages
    7 153
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Canada

    Informations professionnelles :
    Activité : Network game programmer

    Informations forums :
    Inscription : Juin 2010
    Messages : 7 153
    Billets dans le blog
    4
    Par défaut
    Est-on vraiment en C++ ? En dehors de l'utilisation de cout, on en est loin.
    Pensez à consulter la FAQ ou les cours et tutoriels de la section C++.
    Un peu de programmation réseau ?
    Aucune aide via MP ne sera dispensée. Merci d'utiliser les forums prévus à cet effet.

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2018
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2018
    Messages : 2
    Par défaut
    ban oui c du C++

  4. #4
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 505
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 505
    Par défaut
    ban oui c du C++
    Bin tient, et depuis quelle version de la norme C++ on a le droit à des VLA ???
    std::array et std::vector sont tes amis.
    les VLA, NON !!!

  5. #5
    Rédacteur/Modérateur


    Homme Profil pro
    Network game programmer
    Inscrit en
    Juin 2010
    Messages
    7 153
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Canada

    Informations professionnelles :
    Activité : Network game programmer

    Informations forums :
    Inscription : Juin 2010
    Messages : 7 153
    Billets dans le blog
    4
    Par défaut
    Je ne vois aucun VLA juste des fuites mémoires.
    Pensez à consulter la FAQ ou les cours et tutoriels de la section C++.
    Un peu de programmation réseau ?
    Aucune aide via MP ne sera dispensée. Merci d'utiliser les forums prévus à cet effet.

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 397
    Par défaut
    Par contre, c'est néanmoins vrai que ce code est plus du "C avec new et cout"* que du "vrai C++", bien qu'il soit techniquement un code qu'un compilo C++ accepte.

    Un bon crible d’Ératosthène utiliserait un vecteur de booléens pour indiquer quels nombres ont été "vus": Il est inutile de mémoriser les nombres eux-mêmes dans le tableau du crible, vu que leur valeur est égale à leur index (ou leur index moins 1 etc., selon la façon dont est organisé le tableau).

    *Incidemment, c'est comme ça qu'on nous avait "initié au C++" en BTS... j'ai dû tout désapprendre quand j'ai appris le C++ proprement dit.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  7. #7
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2005
    Messages
    5 505
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2005
    Messages : 5 505
    Par défaut
    Je ne vois aucun VLA juste des fuites mémoires.
    Ok pour le VLA, j'ai regardé trop rapidement.
    Mais si on regarde le code lui-même, sans prendre en compte la pléthore de mauvais usages, c'est du grand nimportnawak.

    On entre une valeur, elle ne fera pas partie de l'intervalle de recherche, bof, mais bon, ça esquive le "<" au lieu du "<=" de la ligne 20.

    Le tableau commence à tab commence à 0, tab[0] == 0. WHAT ???
    La routine de "nettoyage" est si spéciale que 1 n'est pas premier, WHAT ???

    C'est quoi cette condition toute pété ligne 24 ???

    Ligne 26, on se sert de "tab" à la fois comme tableau d'entré et de sortie, en sachant qu'il est complètement inutile en entré et qu'en l'utilisant en entré, cela transforme le premier nombre nom premier, 4, en diviseur de tous les nombres.

    Dans les faits, vous n'implémentez absolument pas le crible d'Ératosthène, désolé.

    En résumé, utiliser un papier et un crayon, c'est pas surfait, et le débuggeur est notre ami.

    (Mais putain, ce code C++ archaïque, ça pique les yeux)

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 14/06/2014, 17h32
  2. [Généralités] Windev vs Java : crible d'Ératosthène
    Par jurassic pork dans le forum WinDev
    Réponses: 26
    Dernier message: 15/12/2011, 09h42
  3. Algorithme Crible d'Ératosthène en distribué (application réparti)
    Par tomap3 dans le forum Algorithmes et structures de données
    Réponses: 21
    Dernier message: 12/07/2010, 15h15
  4. recuperer la résolution de l'écran
    Par florent dans le forum C++Builder
    Réponses: 11
    Dernier message: 07/06/2002, 15h01

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