服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言栈之顺序栈

C语言栈之顺序栈

2022-09-19 17:43Tkpluto C/C++

这篇文章主要为大家详细介绍了C语言的顺序栈,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

定义

用顺序存储方式实现的栈称为顺序栈,顺序栈对应于顺序表。

设栈中的数据元素的类型是整型,用一个足够长的一维数组s来存放元素,数组的最大容量为STACK_INTSIZE。同时假设栈顶指针top。(在以下的程序中,top不是指向当前的栈顶元素,而是指向下一次将要进栈的元素的存储位置)

顺序栈可以描述如下:

?
1
2
3
4
#define STACK_INTSIZE 50 /*分配栈的最大存储空间*/
#define DataType int /*定义栈中数据元素的类型*/
DataType s[STACK_INTSIZE];/*用来存放栈中数据元素的内存空间*/
int top;/*定义栈顶指针*/

可以用结构体数组来实现顺序栈:

?
1
2
3
4
5
6
7
8
#define STACK_INTSIZE 50
#define DataType int
typedef struct
{
    DataType s[STACK_INTSIZE];
    int top;
} Stack;
Stack *st;/*指针st用来引用一个顺序栈*/

栈顶指针动态地反映了栈中元素的变化情况,top=0时,表示空栈top=1时,表示已经有一个元素进栈进栈时,栈顶指针top上移,top加1top=STACK_INTSIZE,表示栈满出栈时,栈顶指针top下移,top减1

1.建立空栈

?
1
2
3
4
5
6
7
Stack *InitStack()
{
    Stack *s;
    s = (Stack *)malloc(sizeof(Stack));
    s->top = 0;
    return s;
}

2.进栈

?
1
2
3
4
5
6
7
8
9
10
void Push(Stack *st, DataType x)
{
    if (st->top >= STACK_INTSIZE)
        printf("栈已满,不能入栈!\n");/*若栈满则不能进栈,输出出错信息*/
    else
    {
        st->s[st->top] = x;/*元素x进栈*/
        st->top++;/*栈顶指针top加1*/
    }
}

3.出栈

?
1
2
3
4
5
6
7
8
9
void Pop(Stack *st)
{
    if (st->top == 0)
        printf("栈空,不能出栈!\n");/*若栈空则不能出栈,且输出栈空的信息*/
    else/*栈非空*/
    {
        st->top--;/*top减1,元素出栈*/
    }
}

4.读栈顶元素

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
DataType ReadTop(Stack *st)
{
    DataType x;
    if (st->top == 0)
    {
        printf("栈中无元素");
        return (0);
    }
    /*若栈空则返回0*/
    else
    {
        x = st->s[st->top-1];/*取栈顶元素*/
        return (x);/*返回x即栈顶元素的值*/
    }
}

5.遍历栈

结合元素出栈算法和读取栈顶元素算法,使用循环,当st->top=0时结束循环,即可遍历栈

?
1
2
3
4
5
6
7
8
void ShowStack(Stack *st)
{
    while (st->top > 0)
    {
        st->top--;
        printf("%d", st->s[st->top]);
    }
}

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注服务器之家的更多内容!    

原文链接:https://blog.csdn.net/weixin_60921752/article/details/122772938

延伸 · 阅读

精彩推荐
  • C/C++C语言邻接表建立图详解

    C语言邻接表建立图详解

    这篇文章主要介绍了C语言邻接表建立图,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...

    落春只在无意间6462021-12-22
  • C/C++C++归并法+快速排序实现链表排序的方法

    C++归并法+快速排序实现链表排序的方法

    这篇文章主要介绍了C++归并法+快速排序实现链表排序的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    秦枫-_-8442021-11-02
  • C/C++C语言实现简易文本编辑器

    C语言实现简易文本编辑器

    这篇文章主要为大家详细介绍了C语言实现简易文本编辑器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    l4557027074462021-11-04
  • C/C++C++多字节字符与宽字节字符相互转换

    C++多字节字符与宽字节字符相互转换

    最近在C++编程中经常遇到需要多字节字符与宽字节字符相互转换的问题,自己写了一个类来封装wchar_t与char类型间的转换...

    C++教程网2092020-11-12
  • C/C++用while判断输入的数字是否回文数的简单实现

    用while判断输入的数字是否回文数的简单实现

    这篇文章主要介绍了用while判断输入的数字是否回文数的简单实现,需要的朋友可以参考下...

    C语言教程网10682021-01-15
  • C/C++C++ push_back()函数使用详解

    C++ push_back()函数使用详解

    这篇文章主要介绍了C++ push_back()函数使用详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...

    К свободе5242021-10-28
  • C/C++C语言自增(++)和自减(--)实例详解

    C语言自增(++)和自减(--)实例详解

    本篇文章主要介绍了C语言的自增和自减的基本知识,并附有代码示例,以便大家理解,有需要的朋友可以看下...

    C语言教程网9382021-04-09
  • C/C++C++设计模式之工厂模式

    C++设计模式之工厂模式

    本文是C++设计模式系列文章的第一篇,主要给大家讲述下工厂模式,非常的简单实用,有需要的小伙伴可以参考下...

    weixueyuan6582021-04-04