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

Langage SQL Discussion :

Nombres premiers de 1 à 100


Sujet :

Langage SQL

  1. #1
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 170
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 170
    Points : 7 421
    Points
    7 421
    Billets dans le blog
    1
    Par défaut Nombres premiers de 1 à 100
    Bonjour,

    Tiens, je me suis dit "et si je faisais une requête qui retourne tous les nombres premiers de 1 à 100 ?"

    Alors j'ai pondu ça :
    Code sql : 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
     
    with t as
    (
    	select 2 nb
    	union all
    	select nb + 1
    	from t
    	where nb <= 99
    )
    select 1 nb
    union all
    select nb
    from t
    where nb not in (
    	select t1.nb * t2.nb
    	from t t1 cross join t t2
    );

    Inutile, mais on sait jamais, peut-être que ça pourra intéresser quelqu'un !

    Si quelqu'un à une meilleure solution, qu'il n'hésite pas

    Notamment, si quelqu'un sait comment obtenir les nombres premiers au delà... Car max recursion = 100 sur SQL Server, et je trouve ça assez moyen de modifier ce paramètre...

  2. #2
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 170
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 170
    Points : 7 421
    Points
    7 421
    Billets dans le blog
    1
    Par défaut
    Hmmm, suffisait de demander :

    Code sql : 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
     
    with t as
    (
    	select 3 nb
    	union all
    	select nb + 2
    	from t
    	where nb <= 200
    )
    select 1 nb
    union all
    select 2 nb
    union all
    select nb
    from t
    where nb not in (
    	select t1.nb * t2.nb
    	from t t1 cross join t t2
    );

    Cette fois ça va jusqu'à 200. Après, je sais pas aller plus loin

  3. #3
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 386
    Points
    18 386
    Par défaut
    L'été, période creuse !

  4. #4
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 170
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 170
    Points : 7 421
    Points
    7 421
    Billets dans le blog
    1
    Par défaut
    Ça se voit quand que ça ?

  5. #5
    Membre chevronné
    Inscrit en
    Août 2009
    Messages
    1 073
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 1 073
    Points : 1 806
    Points
    1 806
    Par défaut
    C'est pas très optimal tout ça, on se retrouve avec un produit cartésien de 100 par 100 quand il suffirait de n'aller que jusque racine(100) !
    Alors pour 100, ok ça reste de la toute petite volumétrie, mais ne serait-ce que passer à 10 000 et ça va commencer à se ressentir fortement ...

  6. #6
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 170
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 170
    Points : 7 421
    Points
    7 421
    Billets dans le blog
    1
    Par défaut
    Du coup il faudrait faire un truc du genre ?

    Code sql : 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
     
    WITH t1 AS
    (
    	SELECT 3 nb
    	union ALL
    	SELECT nb + 2
    	FROM t1
    	WHERE nb <= 200
    ), t2 AS
    (
    	SELECT 3 nb
    	union ALL
    	SELECT nb + 2
    	FROM t2
    	WHERE nb <= sqrt(200)
    )
    SELECT 1 nb
    union ALL
    SELECT 2 nb
    union ALL
    SELECT nb
    FROM t1
    WHERE nb NOT IN (
    	SELECT t1.nb * t2.nb
    	FROM t1 CROSS JOIN t2
    );

  7. #7
    Membre chevronné
    Inscrit en
    Août 2009
    Messages
    1 073
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 1 073
    Points : 1 806
    Points
    1 806
    Par défaut
    Il est potentiellement intéressant de les ordonner pour limiter encore la volumétrie. À tester !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    NOT IN ( SELECT t1.nb * t2.nb
    	       FROM t1 CROSS JOIN t2
                  WHERE t2.nb <= t1.nb
              )

  8. #8
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 170
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 170
    Points : 7 421
    Points
    7 421
    Billets dans le blog
    1
    Par défaut
    INNER JOIN alors

    Code sql : 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
     
    WITH t1 AS
    (
    	SELECT 3 nb
    	union ALL
    	SELECT nb + 2
    	FROM t1
    	WHERE nb <= 200
    ), t2 AS
    (
    	SELECT 3 nb
    	union ALL
    	SELECT nb + 2
    	FROM t2
    	WHERE nb <= sqrt(200)
    )
    SELECT 1 nb
    union ALL
    SELECT 2 nb
    union ALL
    SELECT nb
    FROM t1
    WHERE nb NOT IN (
    	SELECT t1.nb * t2.nb
    	FROM t1 INNER JOIN t2 ON t2.nb <= t1.nb
    );

  9. #9
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 849
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 849
    Points : 52 978
    Points
    52 978
    Billets dans le blog
    6
    Par défaut
    Essaye :

    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
    WITH 
    T_10 AS
    (SELECT 0 AS N
     UNION ALL
     SELECT N + 1
     FROM T_10
     WHERE N < 9
    ),
    T_10000 AS
    (SELECT T1.N + 10 * T2.N + 100 * T3.N + 1000 * T4.N AS N
     FROM   T_10 AS T1
            CROSS JOIN T_10 AS T2
    		CROSS JOIN T_10 AS T3
    		CROSS JOIN T_10 AS T4
    )
    SELECT N
    FROM   T_10000
    --ORDER BY 1
    WHERE  N NOT IN (SELECT T1.N
    	             FROM   T_10000 AS T1
    			            INNER JOIN T_10000 AS T2
    				               ON T2.N BETWEEN 2 AND T1.N - 1
    			     WHERE  T1.N % NULLIF(T2.N, 0) = 0)
    ORDER BY 1
    A +

Discussions similaires

  1. [défi n°8]: premiers nombres premiers
    Par javatwister dans le forum Général JavaScript
    Réponses: 41
    Dernier message: 14/06/2005, 10h22
  2. [LG]Calcul des 15 premiers nombres premiers
    Par yffick dans le forum Langage
    Réponses: 12
    Dernier message: 18/09/2004, 14h57
  3. Cripter avec des nombres premiers
    Par clovis dans le forum Algorithmes et structures de données
    Réponses: 3
    Dernier message: 14/04/2004, 19h10
  4. premier nombre premier superieur à m=10^100+1
    Par azman0101 dans le forum Mathématiques
    Réponses: 4
    Dernier message: 17/04/2003, 03h23

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