建立一个顺序栈,实现入栈,出栈和取栈顶元素的操作用C语言
时间: 2024-09-30 12:15:33 浏览: 41
栈的基本操作的实现c语言
在C语言中,我们可以创建一个简单的顺序栈数据结构,它通常通过数组实现。这里是一个基础版本的顺序栈实现:
```c
#include <stdio.h>
#include <stdlib.h>
#define MAX_SIZE 100 // 定义栈的最大容量
typedef struct {
int top; // 栈顶指针
int data[MAX_SIZE]; // 存储数据的数组
} Stack;
// 初始化栈
void init(Stack *stack) {
stack->top = -1;
}
// 判断栈是否为空
int is_empty(Stack *stack) {
return stack- 1;
}
// 入栈操作
void push(Stack *stack, int value) {
if (is_full(stack)) {
printf("Stack is full.\n");
return;
}
stack->top++;
stack->data[stack->top] = value;
}
// 出栈操作
int pop(Stack *stack) {
if (is_empty(stack)) {
printf("Stack is empty.\n");
return -1; // 返回一个特殊值表示栈空
}
int value = stack->data[stack->top];
stack->top--;
return value;
}
// 取栈顶元素操作,但不会改变栈的状态
int peek(Stack *stack) {
if (is_empty(stack)) {
printf("Stack is empty.\n");
return -1;
}
return stack->data[stack->top];
}
int main() {
Stack s;
init(&s);
push(&s, 1);
push(&s, 2);
push(&s, 3);
printf("Top element is: %d\n", peek(&s)); // 输出:Top element is: 3
printf("Popped element is: %d\n", pop(&s)); // 输出:Popped element is: 3
printf("Top element after pop is: %d\n", peek(&s)); // 输出:Top element after pop is: 2
return 0;
}
```
阅读全文