用c语言写一个程序一个顺序栈中连续进入两个元素
时间: 2024-10-10 15:08:01 浏览: 31
在C语言中,你可以使用数组来实现一个简单的顺序栈结构。为了连续地进入并存储两个元素,你需要创建一个大小大于等于两个元素的数组,并维护一个指针指向栈顶。这里是一个简单的示例:
```c
#include <stdio.h>
#define MAX_SIZE 5 // 栈的最大容量,这里是5,可以容纳两个元素
typedef struct {
int data[MAX_SIZE]; // 存储数据的数组
int top; // 栈顶指针
} Stack;
// 初始化栈
void init(Stack *s) {
s->top = -1;
}
// 判断栈是否已满
int isFull(Stack *s) {
return (s->top == MAX_SIZE - 1);
}
// 判断栈是否为空
int isEmpty(Stack *s) {
return (s->top == -1);
}
// 入栈操作(连续插入)
void push(Stack *s, int value1, int value2) {
if (!isFull(s)) {
s->data[++s->top] = value1;
s->data[++s->top] = value2;
} else {
printf("Stack overflow! Cannot push more elements.\n");
}
}
// 出栈操作
void pop(Stack *s) {
if (!isEmpty(s)) {
s->top--;
} else {
printf("Stack underflow! Cannot pop an element.\n");
}
}
int main() {
Stack stack;
init(&stack);
// 连续入栈
push(&stack, 10, 20);
push(&stack, 30, 40); // 如果栈未满,这行会继续添加新的元素
// 可以在这里查看当前栈的内容,由于没有出栈操作,打印出来就是两个连续的元素
for (int i = 0; i <= stack.top; ++i) {
printf("%d ", stack.data[i]);
}
return 0;
}
```
在这个例子中,`push()`函数接受两个元素作为参数并依次将它们压入栈中。注意,如果栈已满,这个操作不会成功,而是会显示一条错误消息。
阅读全文
相关推荐
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)
![-](https://img-home.csdnimg.cn/images/20241231044955.png)
![-](https://img-home.csdnimg.cn/images/20241231045053.png)
![-](https://img-home.csdnimg.cn/images/20241231044930.png)
![-](https://img-home.csdnimg.cn/images/20241231044930.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![ppt](https://img-home.csdnimg.cn/images/20241231044937.png)
![-](https://img-home.csdnimg.cn/images/20241231044937.png)
![-](https://img-home.csdnimg.cn/images/20250102104920.png)
![-](https://img-home.csdnimg.cn/images/20241231044955.png)
![-](https://img-home.csdnimg.cn/images/20241231044937.png)
![-](https://img-home.csdnimg.cn/images/20241231045021.png)