Files
DataStructureC//顺序栈获取栈顶元素.c

64 lines
987 B
C

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#define MaxSize 10
typedef struct{
int data[MaxSize]; //静态数组存放栈中元素
int top; //栈顶指针
}SqStack;
//初始化栈
void InitStack(SqStack *S){
S->top = -1;
}
//新元素进栈
bool Push(SqStack *S,int x){
if(S->top==MaxSize-1){
return false;
}
S->top += 1;
S->data[S->top] = x;
return true;
}
//出栈操作
int Pop(SqStack *S,int x){
if(S->top==-1){
return false;
}
x = S->data[S->top];
S->top -= 1;
return x;
}
//读取栈顶元素操作
bool getTop(SqStack *S,int *x){
if(S->top==-1){
return false;
}
*x = S->data[S->top];
S->top -= 1;
return true;
}
//打印
void PrintStack(SqStack S){
if(S.top==-1){
printf("栈为空!");
}
for(int i=0;i<=S.top;i++){
printf("%d\n",S.data[i]);
}
}
int main(){
SqStack S;
int x = -1;
InitStack(&S);
Push(&S,1);
Push(&S,2);
Push(&S,3);
Push(&S,4);
Push(&S,5);
getTop(&S,&x);
printf("栈顶元素为:%d",x);
return 0;
}