Ki peut me fair 1 exercice PASCAL !!!

[Résolu/Fermé]
Signaler
-
Messages postés
16405
Date d'inscription
samedi 31 mai 2008
Statut
Modérateur
Dernière intervention
20 octobre 2021
-
Bonsoir a tous ,
l'exercice consiste a écrir 1 programme qui cherche et affiche les entiers naturels premiers inférieurs a 100 .
(naturel : n'est divisible que par 1 et lui meme , en + , 1 n'est pas premier .)
je sais qu'il faut utiliser la structure 'pour' (controle itérative ) mais je ne sais pas pk il marche pas
svp aidez moi , mon dv. d'info. est demain !!!
nb : j'ai pascal version 1.5

6 réponses

Messages postés
270
Date d'inscription
samedi 19 avril 2008
Statut
Membre
Dernière intervention
28 décembre 2009
25
le langage pascal est très limité et je l'utilise que pous raffraichire la logique de programmation en je travas sur d'autre logociel.
1
Merci

Quelques mots de remerciements seront grandement appréciés. Ajouter un commentaire

CCM 41713 internautes nous ont dit merci ce mois-ci

Messages postés
270
Date d'inscription
samedi 19 avril 2008
Statut
Membre
Dernière intervention
28 décembre 2009
25
les valeurs sont
2,3,5,7,11,......
le pgrogramme contient une boucle (tantque <condition> faire ........) ou (Repeter ....... jusqu'à <Condition>
Messages postés
16405
Date d'inscription
samedi 31 mai 2008
Statut
Modérateur
Dernière intervention
20 octobre 2021
2 900
program mikeechoromio;

const max=100;

type solution=record
     n:integer;
     a:array[1..max] of integer;
     end;

function PremierJusqua(i:integer;s:solution):boolean;
var j:integer;
begin
     for j:=1 to s.n do
         if (i mod s.a[j])=0 then exit(false);
     result:=true;
end;

function NombresPremiers:solution;
var i:integer;
begin
     result.n:=0;
     for i:=2 to max do
         if PremierJusqua(i,result) then begin
                                         inc(result.n);
                                         result.a[result.n]:=i;
                                         end;
end;

var s:solution; k:integer;
begin
     s:=NombresPremiers;
     for k:=1 to s.n do
         writeln(s.a[k]);
     readln;
end.
Messages postés
270
Date d'inscription
samedi 19 avril 2008
Statut
Membre
Dernière intervention
28 décembre 2009
25
salut,
votre programme présente des erreurs
par exemples la variable result ou est son déclaration
quand même vous avez essayer,c'est bien de votre par
Messages postés
16405
Date d'inscription
samedi 31 mai 2008
Statut
Modérateur
Dernière intervention
20 octobre 2021
2 900
salut, j'utilise Dev-Pascal où j'ai vérifié le programme qui marche très bien.

La variable result n'a jamais besoin d'être déclaré car il s'agit d'un résultat lié à une fonction (donc automatiquement déclaré de type boolean dans PremierJusqua et de type solution dans NombresPremiers).

Comment fais-tu pour attribuer le résultat à une fonction si ce n'est comme ça ?
Messages postés
16405
Date d'inscription
samedi 31 mai 2008
Statut
Modérateur
Dernière intervention
20 octobre 2021
2 900
Ainsi moi je fais :

function plus(a,b:integer):integer;
begin
result:=a+b; // result est déclaré de type integer
end;

Comment tu fais toi ? (ça peux toujours servir...)
Messages postés
270
Date d'inscription
samedi 19 avril 2008
Statut
Membre
Dernière intervention
28 décembre 2009
25
slt,
pour moi le turbo pascal, je n'ai aucune aider de votre langage, mais je remarque dans l'ensemnble il se ressemble.
pour la fonction, c'est de la même manière et j'ajoute en des unités pour que le programme ne soit pas très long.
Messages postés
16405
Date d'inscription
samedi 31 mai 2008
Statut
Modérateur
Dernière intervention
20 octobre 2021
2 900
Bien sûr, Turbo Pascal, Dev-Pascal, son tous deux des programmes, le langage Pascal est lui le même, c'est pourquoi je ne comprends pas ta remarque précédente m'indiquant des erreurs sur cette fonction pourtant très classique...
uses wincrt
var
i,j:integer
begin
for i:=1 to 100 do
j:=1;
repeat
j:=j+1
until i mod j=0;
if i=j then writeln(i);
end.
Messages postés
16405
Date d'inscription
samedi 31 mai 2008
Statut
Modérateur
Dernière intervention
20 octobre 2021
2 900
Ton programme ne marche pas tel quel, j'y ai donc apporté les rectifications nécessaires :
var i,j:integer;
begin
for i:=2 to 100 do
    begin
    j:=1;
    repeat
          j:=j+1
    until i mod j=0;
    if i=j then writeln(i);
    end;
readln;
end.
J'avoue que c'est nettement plus court que mon précédent programme...