用c语言编写程序,实现顺序栈的基本运算,并在此基础上设计一个主程序并完成如下功能: (1)初始化栈s; (2)判断栈s是否非空; (3)依次进栈元素A,B,C,D,E; (4)输出栈内元素个数; (5)输出栈顶元素; (6)输出出栈序列; 实验分析
时间: 2024-10-24 14:11:30 浏览: 85
在 C 语言中,我们可以使用数组作为基础数据结构来实现顺序栈。这里是一个简单的顺序栈实现,包括基本操作的函数定义:
```c
#include <stdio.h>
#define MAX_SIZE 100
typedef struct {
int top;
int data[MAX_SIZE];
} Stack;
// 初始化栈
void init(Stack *s) {
s->top = -1;
}
// 判断栈是否为空
int is_empty(Stack *s) {
return s->top == -1;
}
// 进栈元素
void push(Stack *s, int value) {
if (s->top >= MAX_SIZE - 1) {
printf("Stack overflow!\n");
return;
}
s->data[++s->top] = value;
}
// 输出栈内元素个数
void print_size(Stack *s) {
printf("Stack size: %d\n", s->top + 1);
}
// 输出栈顶元素
void peek(Stack *s) {
if (is_empty(s)) {
printf("Stack is empty.\n");
} else {
printf("Top element: %d\n", s->data[s->top]);
}
}
// 出栈元素
int pop(Stack *s) {
if (is_empty(s)) {
printf("Stack is empty.\n");
return -1; // 返回一个特殊值表示栈空
}
return s->data[s->top--];
}
// 主程序
int main() {
Stack s;
init(&s);
// (3)依次进栈元素A,B,C,D,E;
push(&s, 'A');
push(&s, 'B');
push(&s, 'C');
push(&s, 'D');
push(&s, 'E');
// (4)输出栈内元素个数;
print_size(&s);
// (5)输出栈顶元素;
peek(&s);
// (6)输出出栈序列;
while (!is_empty(&s)) {
printf("%c ", pop(&s));
}
return 0;
}
```
实验分析:
这个程序演示了如何创建、操作顺序栈,包括初始化、入栈、查看大小、获取栈顶元素以及出栈。注意,出栈操作会改变栈的状态,因此需要谨慎处理。此外,在实际应用中,可能还需要考虑栈满的情况,这里我们简单地通过检查栈顶索引来防止溢出。
相关问题:
1. 这段代码为什么使用数组而不是链表实现顺序栈?
2. 顺序栈的优势和劣势是什么?
3. 如果要支持动态扩容,应该如何修改这个栈结构?
阅读全文