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

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

服务器之家 - 编程语言 - C/C++ - C语言实现栈的示例代码

C语言实现栈的示例代码

2023-02-14 15:37MT_125 C/C++

栈是一种特殊的线性表,只允许从一端进出数据,称为后进先出,先进后出。本文主要为大家介绍了C语言实现栈的示例代码,感兴趣的可以了解一下

一、了解栈的结构特点

栈是一种特殊的线性表,只允许从一端进出数据,称为后进先出,先进后出。

压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶

出栈:栈的删除操作叫做出栈。出数据也在栈顶

C语言实现栈的示例代码

二、具体实现

由于栈实质是一种线性表,因此可以用两种方式来实现:顺序表  或  链表

这里我使用的是类似顺序表的方式来实现。

代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
typedef char Stacktype;
typedef struct Stack
{
    int top;
    Stacktype* data;
    int capacity;
}Stack;
 
void Stack_init(Stack* pphead);         //栈的初始化
void Stack_destory(Stack* pphead);      //栈的清空
void Stack_push(Stack* pphead, Stacktype data);  //插入数据,压栈
void Stack_pop(Stack* pphead);          //出栈(删除数据)
bool Stack_Empty(Stack* pphead);        //判断栈是否为空
Stacktype Stack_Top(Stack* pphead);     //调出栈顶元素
int Stack_Size(Stack* pphead);          //查看数据个数
 
//栈的初始化
void Stack_init(Stack* pphead)
{
 
    pphead->top = 0;
    pphead->capacity = 0;
    pphead->data = NULL;
}
//栈的清空
void Stack_destory(Stack* pphead)
{
    pphead->top = 0;
    pphead->capacity = 0;
    free(pphead->data);
    pphead->data = NULL;
}
//插入数据,压栈
void Stack_push(Stack* pphead, Stacktype data)
{
    assert(pphead);
    if (pphead->top == pphead->capacity)
    {
        int Newcapacity = (pphead->capacity == 0) ? 4 : ((pphead->top) * 2);
        Stacktype* temp = NULL;
        temp = (Stacktype*)realloc(pphead->data, sizeof(Stacktype) * Newcapacity);
        if (temp == NULL)
        {
            printf("Stack_push");
            exit(-1);
        }
        pphead->data = temp;
        pphead->top = Newcapacity;
    }
    (pphead->data)[pphead->capacity] = data;
    pphead->capacity++;
}
//出栈(删除数据)
void Stack_pop(Stack* pphead)
{
    assert(pphead);
    assert(Stack_Empty(pphead));
    pphead->capacity--;
}
//判断栈是否为空
bool Stack_Empty(Stack* pphead)
{
    assert(pphead);
    return pphead->capacity != 0;
}
//调出栈顶元素
Stacktype Stack_Top(Stack* pphead)
{
    assert(pphead);
    assert(Stack_Empty(pphead));
    return pphead->data[pphead->capacity - 1];
}
//查看数据个数
int Stack_Size(Stack* pphead)
{
    assert(pphead);
    return pphead->top;
}

补充 栈的用处

我们好不容易实现了一个栈,接下来我们来做个题看看栈有什么用吧。

题目描述

给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

左括号必须用相同类型的右括号闭合。

左括号必须以正确的顺序闭合。

基础框架

C语言的基础框架如下

?
1
2
3
bool isValid(char * s){
 
​​​​​​​}

解题思路

左括号一定要和右括号对齐,非常满足栈的特性

我们可以将所有的左括号存入一个栈中。

然后遇到右括号,就出栈,判断是否匹配。

直到栈为空且字符串中的括号也遍历完了,那么所有括号就正确的匹配了。

代码详解

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
// 1.因为C语言并没有现成的栈,所以我们需要自己造轮子,先写个栈再说
typedef char STDateType; // 更改数据类型为char
 
typedef struct Stack
{
    STDateType* a;
    int top;
    int capacity;
}Stack;
 
void StackInti(Stack* ps)
{
    assert(ps);
    
    ps->a = NULL;
    ps->capacity = 0;
    ps->top = 0;
}
 
void StackDestory(Stack* ps)
{
    assert(ps);
 
    free(ps->a);
    ps->capacity = 0;
    ps->top = 0;
}
 
void StackPush(Stack* ps, STDateType x)
{
    assert(ps);
    if (ps->top == ps->capacity)
    {
        int newCapcity = ps->capacity == 0 ? 4 : ps->capacity * 2;
        ps->a = (int*)realloc(ps->a, sizeof(int) * newCapcity);
        if (ps->a == NULL)
        {
            printf("ralloc error");
            exit(-1);
        }
        ps->capacity = newCapcity;
    }
 
    ps->a[ps->top] = x;
    ps->top++;
}
 
void StackPop(Stack* ps)
{
    assert(ps);
    assert(ps->top > 0);
 
    ps->top--;
}
 
bool StackEmpty(Stack* ps)
{
    assert(ps);
    return ps->top == 0;
}
 
STDateType StackTop(Stack* ps)
{
    assert(ps);
    assert(ps->top > 0);
 
    return ps->a[ps->top - 1];
}
 
bool isValid(char * s){
    Stack a;
    StackInti(&a);
    while(*s)
    {
        if (*s == '(' || *s == '[' || *s == '{') //入栈
        {
            StackPush(&a, *s);
        }
        else //出栈
        {
            if(StackEmpty(&a)) //右括号多一个的情况
            {
                return false;
            }
 
            char tmp = StackTop(&a);
            StackPop(&a);
            if ((*s == ')' && tmp != '(')
              ||(*s == ']' && tmp != '[')
              ||(*s == '}' && tmp != '{') )
            {
                return false;
            }
        }
        s++;
    }
    return StackEmpty(&a); //防止出现多一个左括号的情况
}

到此这篇关于C语言实现栈的示例代码的文章就介绍到这了,更多相关C语言实现栈内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/MT_125/article/details/125470074

延伸 · 阅读

精彩推荐
  • C/C++C语言循环控制入门介绍

    C语言循环控制入门介绍

    大家好,本篇文章主要讲的是C语言循环控制入门介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览...

    七7777442022-08-11
  • C/C++c++ 让程序开机自动启动的方法

    c++ 让程序开机自动启动的方法

    这篇文章主要介绍了c++ 让程序开机自动启动的方法,需要的朋友可以参考下...

    C++教程网12152021-06-02
  • C/C++实例讲解C语言编程中的结构体对齐

    实例讲解C语言编程中的结构体对齐

    这篇文章主要介绍了C语言编程中的结构体对齐,值得注意的是一些结构体对齐的例子在不同编译器下结果可能会不同,需要的朋友可以参考下...

    阿凡卢10842021-03-30
  • C/C++C++嵌套类与局部类详细解析

    C++嵌套类与局部类详细解析

    从作用域的角度看,嵌套类被隐藏在外围类之中,该类名只能在外围类中使用。如果在外围类之外的作用域使用该类名时,需要加名字限定...

    C++教程网11832020-12-26
  • C/C++C++指针与数组:指针详解

    C++指针与数组:指针详解

    本文从初学者的角度,深入浅出地讲解C++中的指针、数组指针,对最常混淆的引用传递、值传递和指针传递做了区处,需要的朋友可以参考下...

    追道者9592021-12-31
  • C/C++C++数据结构与算法的基础知识和经典算法汇总

    C++数据结构与算法的基础知识和经典算法汇总

    终是到了标志着大二结束的期末考试了,对于《算法设计与分析》这门课,我需要总结一下学过的所有算法的思想以及老师补充的关于两个复杂度和递归的...

    对象new不出来7872022-12-09
  • C/C++详解C++编程中的私有继承和公有继承

    详解C++编程中的私有继承和公有继承

    这篇文章主要介绍了详解C++编程中的私有继承和公有继承,是C++入门学习中的基础知识,需要的朋友可以参考下...

    C++教程网12212021-03-14
  • C/C++深入剖析设计模式中的组合模式应用及在C++中的实现

    深入剖析设计模式中的组合模式应用及在C++中的实现

    这篇文章主要介绍了设计模式中的组合模式应用及在C++中的实现,组合模式可以清晰地反映出递归构建树状的组合结构,需要的朋友可以参考下...

    梦在天涯6462021-03-26