Forum: PC-Programmierung Ringspeicher u. Median


von Thomas M. (Gast)


Lesenswert?

Hallo,

ich muss was programmieren und weiss nicht wie.

ich habe ein Array der Grösse 100. In das Array werden kontiuierlich
Werte abgelegt, sortiert (qsort) und der Median wird berechnet.
D.h. ich muss darauf achten, dass nach der Sortierung die Werte nicht
mehr den eigentlich Index haben, z.B. ist der letzte Wert im
Ringspeicher nicht mehr an der Stelle 100. Das ist auch mein Problem,
ich weiss nicht wie ich mir den wahren Index der Werte merken kann,
denn ich muss ja praktisch die letzten 99 Werte berücksichtigen und den
ältersten Wert rausschmeissen und durch einen neuen ersätzen.

Der Median wird nach jedem neu ankommenden Werte bestimmt, dazu muss
ich das Arry sortieren und der Index ist verfälscht.

Hat jemand eine Idee?

von beta-frank (Gast)


Lesenswert?

Hi Thomas,

Speicher und ein Quentchen Zeit wird bei PC-Programmierung und 100
Werten nicht das Thema sein?! Dann leg doch ein zweites array2[100] an.
In das erste array1[100] schreibst Du schön der Reihe nach Deine Werte
und Du weißt immer, wo Dein Index hingehört. Dann kopierst Du:

for(i=0;i<=100;i++) array2[i]=array[i];//Ringspeicher retten

Nun array2 sortieren und den Median berechnen.

Gruß Frank

von beta-frank (Gast)


Lesenswert?

Hi Thomas,

Speicher und ein Quentchen Zeit wird bei PC-Programmierung und 100
Werten nicht das Thema sein?! Dann leg doch ein zweites array2[100] an.
In das erste array1[100] schreibst Du schön der Reihe nach Deine Werte
und Du weißt immer, wo Dein Index hingehört. Dann kopierst Du:

for(i=0;i<100;i++) array2[i]=array[i];//Ringspeicher retten

Nun array2 sortieren und den Median berechnen.

Gruß Frank

von Thomas M. (Gast)


Lesenswert?

Die Idee ist super und wirklich logisch.

Vieln Dank!

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.