Betrachten Sie einen Stapel, mit einem Maximum von 100 Int. Wie folgt definiert:Stapel in C. Speichern Popant Top-Ergebnisse
#define MAX 100
typedef struct stack {
int size;
int values[MAX];
} STACK;
ich dieses Pop-Funktion haben:
int pop(STACK *s, int *x){
if (s->size == 0) return 1;
int *p = s->values + s->size--;
*x = *p;
return 0;
}
Welche soll Werte [MAX] letzte Element entfernen, speichern diesen Wert bei x-Adresse und dann 0 zurück, wenn der Erfolg;
Weitere Funktionen:
int top(STACK *s, int *x){
if (s->size == 0) return 1;
int *p = s->values + s->size;
*x = *p;
return 0;
} //like pop function, it should store top element at address x.
void initStack(STACK *s){
s->size = 0;
}
int push(STACK *s, int x){
if (s->size >= MAX) return 1;
int *p = (s->values);
*(p + s->size++) = x;
return 0;
}
Das ist mein Haupt. Es schlägt fehl, nur auf dem ersten Pop-Aufruf:
int main(){
struct stack s;
STACK *p = &s;
int i;
int x,y,z,w,t;
initStack(p);
for(i = 0; i < MAX; i++)
push(p,i);
int res = push(p,MAX);
for(i = 0; i < MAX; i++)
printf("%d|", p->values[i]);
printf("\nLast insertion: %d",res);
pop(p,&x);
pop(p,&y);
pop(p,&z);
pop(p,&w);
top(p,&t);
printf("\nThe elements %d|%d|%d|%d were removed. Current stack size: %d . Top element: %d.",x,y,z,w,p->size,t);
return 0;
}
Ergebnisse (nur letzte printf):
The elements 1|99|98|97 were removed.Current stack size: 96 .Top element: 96.
Aus irgendeinem Grunde erster Pop-Aufruf fehlschlägt,, die nicht nur die Liste der entfernten Elemente verurteilt, aber auch das oberste Element Ergebnis. Irgendwelche Vorschläge warum?
was 'push'? –
Und * mach das nicht: 'int * p = s-> Werte + s-> Größe -' bitte. –
Tritt das Problem nur auf, wenn Sie den Stapel vollständig füllen? (Bitte posten Sie auch 'push' und' initStack'.) – molbdnilo