Précédent   Forum du club des développeurs et IT Pro > Autres langages > Pascal
Pascal Forum d'entraide sur la programmation en langage Pascal et sur les EDI. Avant de poster -> la F.A.Q Pascal, les cours
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse
 
Outils de la discussion
Publicité
'
Vieux 29/04/2012, 01h35   #1
L33vi7
 
Homme
Étudiant
Inscription : avril 2012
Messages : 6
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : avril 2012
Messages : 6
Points : -2
Points : -2
Par défaut Suite non triviale

Bonjour (dommage qu'il n'y ait pas une interface $ \ Latex $ sur le forum)

J'aimerais bien pouvoir formaliser, manipuler(calculer les termes d') une suite récurrente en pascal , notamment

un = somme ( u_p*u_(n-p) , pour p=1 jusqu'a n-1)
u1 et u2 - fixés

u3 = (u1*u2+u2*u1)/2 par exemple .

évidemment il me parait impossible de déclarer tous les u_i , via var : u_i : real.

Une idée était aussi de séparer n pair et impair , mais même si je simplifie (disons) l’expression de cette manière , l'ordi n'en voudra pas de cela .

Bref , je n'ai jamais rencontré ce genre d'expressions et google ne s'y connait pas non plus .
Pourriez-vous donc me donner une idée de comment le faire? ,
(j'ai essayé de définir une procédure ,mais c'est surtout le grand nombre de termes qui me gêne)
L33vi7 est déconnecté   Envoyer un message privé Réponse avec citation 01
Vieux 29/04/2012, 11h38   #2
M.Dlb
Rédacteur/Modérateur

 
Avatar de M.Dlb
 
Inscription : avril 2002
Messages : 2 278
Détails du profil
Informations personnelles :
Âge : 28

Informations forums :
Inscription : avril 2002
Messages : 2 278
Points : 3 434
Points : 3 434
Aux premiers abords, on pense à de la récurrence, ce qui facilite le problème.

Mais il se peut qu'au bout d'un certain nombres de valeurs, ça plante (explosion de la pile). As-tu des contraintes ? Un nombre p maximal ?
__________________
M.Dlb - Modérateur z/OS - Rédacteur et Modérateur Pascal
M.Dlb est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/04/2012, 12h44   #3
L33vi7
 
Homme
Étudiant
Inscription : avril 2012
Messages : 6
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : avril 2012
Messages : 6
Points : -2
Points : -2
U1 et u2 sont petits (il s'agit de programmer cette suite afin de faire des conjectures sur sa convergence et dans les deux cas je peux me limiter a u1 et u2 < 2 ) (la suite est un peux plus difficile et j'ai posté que la partie qui pose problème).

De plus, la difficulté (pour moi) est de construire cette récurrence, car je ne vois pas comment l'intégrer dans une boucle

il s'agit précisément de sommer les u_i*u_j tels que i+j = n-1 (on obtient alors u_n) et ca je ne vois pas comment faire, qu'est-ce que vous voulez dire par "explosion de la pile " ?
je pourrais me limiter a un n <10^5 ou plus petit , suffit de m'assurer que la suite converge ou diverge .

Merci pour votre réponse wormful_sickfoot.
L33vi7 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/04/2012, 21h35   #4
L33vi7
 
Homme
Étudiant
Inscription : avril 2012
Messages : 6
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : avril 2012
Messages : 6
Points : -2
Points : -2
Code :
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
program pr;
uses crt;
var a,b,e,g,h,c,u1,u2:real;
 
function f(k:integer):real;
var c : integer;
begin
 
if k=1 then f:=u1;
if k=2 then f:=u2;
if k>2 then
a:=0;
begin
 
for c:=1 to k-1 do
begin
b:=f(c)*f(k-c);
a:=a+b;
f:=a;
end;
 
end;
end;
 
begin
clrscr;
u1:=0.5;
u2:=1.5;
f(3);
f(4);
writeln(f(4):1:3);
readln;
end.


Moi c'est plutot comme ca que je le vois mais ,déja u4 est fausse, et ainsi toutes les autres valeurs (u1 et u2 je les ais fixé car c'est ce cas qui m'intéresse maintenant)

Peut-etre utiliser (procedure)?

ou pourriez vous m'éclairer , pourquoi le programme ne marche pas?
L33vi7 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 29/04/2012, 22h45   #5
M.Dlb
Rédacteur/Modérateur

 
Avatar de M.Dlb
 
Inscription : avril 2002
Messages : 2 278
Détails du profil
Informations personnelles :
Âge : 28

Informations forums :
Inscription : avril 2002
Messages : 2 278
Points : 3 434
Points : 3 434
Les blocs begin/end de la condition k>2 ne sont pas bons !
__________________
M.Dlb - Modérateur z/OS - Rédacteur et Modérateur Pascal
M.Dlb est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/04/2012, 07h25   #6
L33vi7
 
Homme
Étudiant
Inscription : avril 2012
Messages : 6
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : avril 2012
Messages : 6
Points : -2
Points : -2
mais, (d'après moi ) il est bien construit , car pour chaque valeur entre 1 et k-1 on associe à "a" la somme des u_c*u(k-c) et c'est effectivement la suite cherchée. (sauf qu'en pratique pour k=4 cela ne marche plus) et puis je suis moins sur d'associer a f(3) la valeur de "a" par : f:=a;

Merci de m'éclairer ou repose effectivement le problème (dans la construction de for ou dans une des lignes de code du /begin - /end qui marche pas ) car je crois que même après avoir passé beaucoup su temps sur la théorie , la pratique m'échappe...
L33vi7 est déconnecté   Envoyer un message privé Réponse avec citation 01
Vieux 30/04/2012, 10h18   #7
droggo
Expert Confirmé
 
Inscription : août 2006
Messages : 3 433
Détails du profil
Informations forums :
Inscription : août 2006
Messages : 3 433
Points : 3 808
Points : 3 808
Hia,

Au coup d’œil, je suis de l'avis de wormful_sickfoot, revois les blocs begin ... end.
__________________
Il court en ce moment une espèce de grippe, mais elle ne court pas très vite, car on peut l'attraper sans courir.
droggo est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/04/2012, 22h28   #8
L33vi7
 
Homme
Étudiant
Inscription : avril 2012
Messages : 6
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : avril 2012
Messages : 6
Points : -2
Points : -2
Je n'arrive pas , j'ai essayé l'ensemble de combinaisons possibles sur pascal et chaque fois j'ai les faux termes de la suite, l'enchainement logique est bon ,
peut-etre que la commande function me cache quelque chose dans son comportement?
serait-il mieux d'utiliser procedure?
L33vi7 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/04/2012, 23h19   #9
droggo
Expert Confirmé
 
Inscription : août 2006
Messages : 3 433
Détails du profil
Informations forums :
Inscription : août 2006
Messages : 3 433
Points : 3 808
Points : 3 808
Joe,

Quand on contrôle un programme pour un problème de blocs begin...end, on commence par le mettre en forme.
Code :
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
program pr;
uses crt;
var a,b,e,g,h,c,u1,u2:real;
 
function f(k:integer):real;
var c : integer;
begin 
  if k=1 then f:=u1;
  if k=2 then f:=u2;
  if k>2 then
    a:=0;
 
  begin 
    for c:=1 to k-1 do
    begin
      b:=f(c)*f(k-c);
      a:=a+b;
      f:=a;
    end; 
  end;
 
end;
 
begin
  clrscr;
  u1:=0.5;
  u2:=1.5;
  f(3);
  f(4);
  writeln(f(4):1:3);
  readln;
end.
Et comme ça, tu ne vois pas de problème de blocs ?

De plus, pour contrôler, surtout un petit programme comme celui-ci, on l'exécute à la main, instruction par instruction, en suivant le code écrit, et pas ce qu'on pense avoir fait.

Précision : je n'ai pas testé, et je ne pense pas le faire, car tu peux t'en sortir tout seul avec un minimum d'effort.
__________________
Il court en ce moment une espèce de grippe, mais elle ne court pas très vite, car on peut l'attraper sans courir.
droggo est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 12/05/2012, 10h54   #10
L33vi7
 
Homme
Étudiant
Inscription : avril 2012
Messages : 6
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : avril 2012
Messages : 6
Points : -2
Points : -2
Résolu avec en considerant a: array [1..1000] of real et en faisant une recurrence.

Est-ce que par ailleurs en utilisant un for on augmente la rapidité du calcul par rapport à l'utilisation d'une fonction ?
L33vi7 est déconnecté   Envoyer un message privé Réponse avec citation 01
Réponse
Outils de la discussion

Navigation rapide


Fuseau horaire GMT +2. Il est actuellement 19h53.


 
 
 
 
Partenaires

Hébergement Web