用C语言编程实现以下功能: 用栈的顺序结构存储数据,用C语言实现栈的初始化、入栈操作、出栈操作、显示栈中所有元素、判断栈空栈满、统计栈中元素个数、查找某元素是否在栈中。
时间: 2024-10-25 09:05:24 浏览: 23
在C语言中,我们可以使用数组或者链表来实现栈的数据结构。这里我会给出一种基于数组的简单实现,因为数组更直观,适合初学者理解。
```c
#include <stdio.h>
#define MAX_SIZE 10 // 定义栈的最大容量
typedef struct {
int data[MAX_SIZE]; // 存储元素的数组
int top; // 栈顶指针
} Stack;
// 初始化栈
void init(Stack *s) {
s->top = -1;
}
// 入栈操作(将元素添加到栈顶)
void push(Stack *s, int value) {
if (s->top < MAX_SIZE - 1) { // 检查栈是否已满
s->data[++s->top] = value;
} else {
printf("Stack is full.\n");
}
}
// 出栈操作(删除并返回栈顶元素,如果为空则返回-1)
int pop(Stack *s) {
if (s->top == -1) return -1; // 检查栈是否为空
return s->data[s->top--];
}
// 显示栈中所有元素
void display(Stack *s) {
if (s->top != -1) {
for (int i = 0; i <= s->top; ++i) {
printf("%d ", s->data[i]);
}
printf("\n");
} else {
printf("Stack is empty.\n");
}
}
// 判断栈是否为空
int isEmpty(Stack *s) {
return s->top == -1;
}
// 判断栈是否已满
int isFull(Stack *s) {
return s->top == MAX_SIZE - 1;
}
// 统计栈中元素个数
int size(Stack *s) {
return s->top + 1; // 加1是因为包括栈顶元素
}
// 查找某个元素是否在栈中
bool search(Stack *s, int target) {
for (int i = 0; i <= s->top; ++i) {
if (s->data[i] == target) {
return true;
}
}
return false;
}
int main() {
Stack stack;
init(&stack);
// 使用示例
push(&stack, 5);
push(&stack, 10);
display(&stack); // 输出: 10 5
printf("Top element: %d\n", pop(&stack)); // 输出: 5
阅读全文