用C语言编程实现以下功能: 用栈的链式结构存储数据,用C语言实现栈的初始化、入栈操作、出栈操作、显示栈中所有元素、判断栈空栈满、统计栈中元素个数、查找某元素是否在栈中。
时间: 2024-10-25 17:06:03 浏览: 23
在C语言中,我们可以使用链表来实现栈的功能。这里是一个简单的示例,我们将创建一个`Node`结构体作为链表节点,以及一个`Stack`结构体来封装这些操作:
```c
#include <stdio.h>
#include <stdlib.h>
// 定义栈的链表节点
typedef struct Node {
int data;
struct Node* next;
} Node;
// 定义栈结构体
typedef struct Stack {
Node* top;
int size; // 栈容量
} Stack;
// 初始化栈
void init(Stack* stack) {
stack->top = NULL;
stack->size = 0;
}
// 入栈操作
void push(Stack* stack, int value) {
if (stack->size == 0) {
Node* newNode = (Node*)malloc(sizeof(Node));
newNode->data = value;
newNode->next = NULL;
stack->top = newNode;
} else {
Node* newNode = (Node*)malloc(sizeof(Node));
newNode->data = value;
newNode->next = stack->top;
stack->top = newNode;
}
stack->size++;
}
// 出栈操作
int pop(Stack* stack) {
if (stack->top == NULL) {
printf("Stack is empty.\n");
return -1; // 标志栈为空
} else {
int value = stack->top->data;
Node* temp = stack->top;
stack->top = stack->top->next;
free(temp);
stack->size--;
return value;
}
}
// 显示栈中所有元素
void display(Stack* stack) {
if (stack->top == NULL) {
printf("Stack is empty.\n");
} else {
Node* node = stack->top;
while (node != NULL) {
printf("%d ", node->data);
node = node->next;
}
printf("\n");
}
}
// 判断栈是否为空
int isEmpty(Stack* stack) {
return stack->top == NULL;
}
// 判断栈是否已满(假设固定大小)
int isFull(Stack* stack) {
return stack->size == stack->size;
}
// 统计栈中元素个数
int count(Stack* stack) {
return stack->size;
}
// 查找元素是否存在
int search(Stack* stack, int value) {
Node* node = stack->top;
while (node != NULL) {
if (node->data == value)
return 1; // 找到
node = node->next;
}
return 0; // 没找到
}
```
阅读全文