Bonjour à tous
voici un exercice d'algorithmique qui traite les tableaux:
Soit T un tableau d'entiers de taille N. Une série dans T est une suite d'éléments consécutifs et égaux de T. le problème consiste à trouver la plus longue série dans T, l'indice de son premier élément et sa longueur
Par exemple
T 2 2 6 6 6 6 9 9 9 9 9 1 0 0 0
le programme affichera la série est 9 elle commence à l'indice 7 et elle est de longueur 5
Voici ma proposition
ce programme tourne correctement, mais il affiche dans tous les cas la série d'indice 2
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
57
58
59 uses wincrt; type tab=array[1..100] of integer; var m,v,t:tab; j,i, p, nbmax,posi,nb,n:integer; begin write('siaisr N= '); readln(n); for i:=1 to n do begin write('T[',i,']='); readln(t[i]); end; i:=1; nb:=1; repeat nb:=nb+1; i:=i+1; until (t[i]<>t[i+1]); j:=i+1; nbmax:=1; posi:=1; repeat if t[j]=t[j+1] then begin nbmax:=nbmax+1; j:=j+1; end; p:=j; until (t[j]<>t[j+1]) or (j>=n-1); if nb>nbmax then begin nbmax:=nb; p:=i; posi:=1; end else posi:=i+1; writeln('la serie est: ',t[p], ' l''indice ',posi, ' la longueur est: ',nbmax); end.
Pouvez vous m'aider ?
Partager