使用一维数组实现共享栈操作

Posted jearchen

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用一维数组实现共享栈操作相关的知识,希望对你有一定的参考价值。

所谓的共享栈就是两个虚拟的栈使用一块固定大小的数组元素,涉及到如何不冲突的进行入栈出栈操作。对一维数组即在数组两头设置两个栈顶标记(指针)。然后分别这两个进行入栈出栈操作。当前面的栈标记位置+1=后面栈的位置,那么不可以进行入栈操作,如果两个栈有在栈底(对前面的来说是top1==-1,后一个是top2==n)是不可以进行出栈操作的。
结构图如下:
技术分享图片

//函数根据operate这个字符串内容是push还是pop,flag是1还是2表示是前面一部分栈还是后一部分栈,n表示共享栈stack_array[]数组的长度
#include<iostream>
#include<string>
using namespace std;
int top1,top2;//栈顶指针在整个过程是变化的,记录着两个栈栈顶位置,需要设置为全局变量
char sharestack(char stack_array[],int top,int flag,string operate)
{
    if(operate=="push")
    {
        if(flag==1)
        {
            char stack1_number;
            stack1_number=‘q‘;
            stack_array[top]=stack1_number;
            return 0;
        }
        if(flag==2)
        {
            char stack2_number;
            stack2_number=‘r‘;
            stack_array[top]=stack2_number;
            return 0;
        }
    }
    if(operate=="pop")
    {
        if(flag=1)
        {
            char stack1_popnumber;
            stack1_popnumber=stack_array[top];
            return stack1_popnumber;
        }
        if(flag=2)
        {
            char  stack2_popnumber;
            stack2_popnumber=stack_array[top];
            return stack2_popnumber;
        }
    }
}
int main()
{
    
    char stack_array[10]={‘0‘};//初始化字符数组
    top1=-1;
    top2=10;//初始化1、2号栈栈顶指针
    //2号栈入栈基本操作,将top的变化放在main中执行,实现连续入栈或出栈。
    if(top1+1!=top2)//栈不满则入
    {
        top2=top2-1;
        sharestack(stack_array,top2,2,"push");
    }
    //2号栈入栈
    if(top1+1!=top2)
    {
        top2=top2-1;
        sharestack(stack_array,top2,2,"push");
    }
    cout<<"后面一个栈入一个元素:"<<stack_array[8]<<endl;

    //1号栈入栈
    if(top1+1!=top2)
    {
        top1=top1+1;
        sharestack(stack_array,top1,1,"push");
        cout<<"前面一个栈入一个元素:"<<stack_array[0]<<endl;
    }

    //2号栈出栈
    if(top2!=10)//出栈时2号栈的栈顶指针不为空是指不为(下标最大值+1)
    {
        char stack_pop_number;
        stack_pop_number=sharestack(stack_array,top2,2,"pop");
        top2=top2+1;
        cout<<"后面一个栈出一个元素"<<stack_pop_number<<endl;
    }

    //1号栈出栈
    if(top1!=-1)//一号栈出栈时基本栈顶指针不为下标(最小值0-1)
    {
        char stack_pop_number;
        stack_pop_number=sharestack(stack_array,top1,1,"pop");
        top1=top1-1;
        cout<<"前面一个栈出一个元素"<<stack_pop_number<<endl;
    }
    return 0;
}

技术分享图片
在此次编写的过程中遇到不能进行连续代码入栈或者出栈的问题,在每次出入栈都要进行相应的数据操作,可以考虑将其封装在函数中。




以上是关于使用一维数组实现共享栈操作的主要内容,如果未能解决你的问题,请参考以下文章

一维数组模拟数据结构-------栈

栈文档之共享栈

ADT - 两个栈共享一个数组

一维数组和面向对象基础知识

数据结构-栈(C++实现)

使用共享内存对三维数组的一维求和