当前位置: 首页 > news >正文

做网站一般需要哪些文件夹?班级优化大师官网登录

做网站一般需要哪些文件夹?,班级优化大师官网登录,做网站怎么做其他页,厦门做网站建设目录 栈的概念及结构 栈的实现 创建栈 栈的初始化 入栈 出栈 取出栈顶数据 判断栈是否为空 有效数据个数 栈的销毁 全代码 stack.h stack.c 应用 题目 示例 解题思路 代码实现 栈的概念及结构 栈是一种特殊的线性表,其只允许在固定的一端进行插入…

目录

栈的概念及结构

栈的实现

创建栈

栈的初始化

入栈

出栈

取出栈顶数据

判断栈是否为空

有效数据个数

栈的销毁

全代码

stack.h

stack.c

应用

题目

示例

解题思路

代码实现


栈的概念及结构

     栈是一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。你也可以一边入一边出。

ab6ac3c165d14946b995f1be45a61c3a.png

     栈顶和栈底并不是固定的,这是人为决定的。

栈的实现

     栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些。因为数组在尾上插入数据的代价比较小。

     以下的内容如果你对顺序表的实现熟悉的话就很简单。

创建栈

     栈的创建需要有指向动态数组指针,栈顶数据下标和容量

typedef int STDataType;typedef struct Stack
{STDataType* arr;//指向动态数组指针int top;//栈顶数据下标int capacity;//容量
}ST;

栈的初始化

     将arr置为空指针,top置为-1,capacity置为0。

//初始化
void STInit(ST* pst)
{assert(pst);pst->arr = NULL;pst->top = -1;pst->capacity = 0;
}

     这里的top为什么要是-1呢?

     一般来说top应该也是0,这里是-1是为了确保top是栈顶数据的下标。当然了你要是想写0也是可以的。

入栈

     入栈又称压栈,进栈。

     首先要判断容量是否够用,如果不够用的话就扩容。然后再把数据塞入即可。

3e2a82dbe4434d56a58a320d45041910.png

//入栈
void STPush(ST* pst, STDataType x)
{assert(pst);if (pst->top + 1 == pst->capacity){pst->capacity = pst->capacity == 0 ? 4 : pst->capacity * 2;STDataType* p = (STDataType*)realloc(pst->arr, sizeof(STDataType) * pst->capacity);if (p == NULL){perror("realloc");return;}pst->arr = p;}pst->arr[++pst->top] = x;
}

     注意:这里要前置++,如果后置就会造成非法访问。如果top是0,就要后置了。

出栈

     这里要另外判断一下栈是否为空。然后只要让top--即可。

3cb3ad12e9474a6a9c91a97b0418ffa2.png

//出栈
void STPop(ST* pst)
{assert(pst);assert(pst->top > -1);pst->top--;
}

取出栈顶数据

     这里也要判断一下栈是否为空。然后返回下标top对应的数据即可。

//取出出栈顶数据
STDataType STTop(ST* pst)
{assert(pst);assert(pst->top > -1);return pst->arr[pst->top];
}

判断栈是否为空

     直接返回pst->top==-1即可。

//判断栈是否为空
bool STEmpty(ST* pst)
{assert(pst);return pst->top == -1;
}

     该函数类型要是布尔类型。

     如果top=-1则返回true,否则返回false。

有效数据个数

     直接返回top+1即可。

//有效数据个数
int STSize(ST* pst)
{assert(pst);return pst->top + 1;
}

栈的销毁

     用free销毁arr,并将它置为空指针。其它的置为初始化值即可。

//销毁
void STDestroy(ST* pst)
{assert(pst);free(pst->arr);pst->arr = NULL;pst->top = -1;pst->capacity = 0;
}

全代码

stack.h

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <assert.h>typedef int STDataType;typedef struct Stack
{STDataType* arr;int top;int capacity;
}ST;//初始化
void STInit(ST* pst);//销毁
void STDestroy(ST* pst);//入栈
void STPush(ST* pst, STDataType x);//出栈
void STPop(ST* pst);//取出出栈顶数据
STDataType STTop(ST* pst);//判空
bool STEmpty(ST* pst);//获取数据个数
int STSize(ST* pst);

stack.c

#include "stack.h"//初始化
void STInit(ST* pst)
{assert(pst);pst->arr = NULL;pst->top = -1;pst->capacity = 0;
}//入栈
void STPush(ST* pst, STDataType x)
{assert(pst);if (pst->top + 1 == pst->capacity){pst->capacity = pst->capacity == 0 ? 4 : pst->capacity * 2;STDataType* p = (STDataType*)realloc(pst->arr, sizeof(STDataType) * pst->capacity);if (p == NULL){perror("realloc");return;}pst->arr = p;}pst->arr[++pst->top] = x;
}//出栈
void STPop(ST* pst)
{assert(pst);assert(pst->top > -1);pst->top--;
}//取出栈顶数据
STDataType STTop(ST* pst)
{assert(pst);assert(pst->top > -1);return pst->arr[pst->top];
}//判断栈是否为空
bool STEmpty(ST* pst)
{assert(pst);return pst->top == -1;
}//有效数据个数
int STSize(ST* pst)
{assert(pst);return pst->top + 1;
}//销毁
void STDestroy(ST* pst)
{assert(pst);free(pst->arr);pst->arr = NULL;pst->top = -1;pst->capacity = 0;
}

应用

题目

a4f138d238f749da886b89dd701e8202.png

该题链接: https://leetcode.cn/problems/valid-parentheses/description/

示例

3b9577022e254ae7a80ec7676e3d5bfb.png

解题思路

     这题根据栈的后进先出边入边出的特性可以解决。

     创建一个栈,只让左括号入栈,让右括号与栈里的数据匹配。如果匹配成功让左括号出栈,继续该操作直至字符串遍历完。如果匹配不成功则直接退出。

有几个要注意的点

  1. 字符串只有右括号
  2. 字符串只有左括号或只剩左或右括号
  3. arr是int的类型,要把它改成char类型

代码实现

bool isValid(char* s) 
{ST st;STInit(&st);while(*s){if(*s == '(' || *s == '[' || *s == '{'){STPush(&st, *s);}else{if(st.top == -1)//字符串只有右括号{STDestroy(&st);return false;}STDataType top = STTop(&st);if(*s == ')' && top != '(' || *s == ']' && top != '[' || *s == '}' && top != '{'){STDestroy(&st);return false;}STPop(&st);}s++;}bool ret = STEmpty(&st);//字符串只有左括号或只剩左或右括号STDestroy(&st);return ret;
}

http://www.hotlads.com/news/2990.html

相关文章:

  • 网站html优化网站seo入门基础教程
  • 湖南新冠疫情最新情况seo快速排名外包
  • 青岛建站开发虎门今日头条新闻
  • php动态网站开发实训报告网站维护
  • 网站静态化设计公众号排名优化
  • 做网站找外包好吗打开网址跳转到国外网站
  • 住房和城乡建设部网站干部学院开网站怎么开
  • 自己做的小网站分享百度指数分析数据
  • 手机web网站开发软件有百度站长工具怎么关闭教程视频
  • 做网站需要哪些费用如何建网站要什么条件
  • 网站制作一般要几天引流推广软件
  • wordpress日主题使用教程app优化方案
  • 外包 网站开发公司怎么在百度上发布信息
  • 做网站用的国外节点服务器举例说明seo
  • 哈 做网站水果店推广营销方案
  • 顺企网贵阳网站建设关键词排名优化公司成都
  • 政府网站建设评析上海seo网站优化软件
  • 推荐网站建设品牌seo技术自学
  • rar在线解压缩网站中级经济师考试
  • 房地产基础知识百度快照优化排名推广怎么做
  • WordPress中文seo而的跟地seo排名点击软件
  • 上海高中生做课题的网站电商软文广告经典案例
  • wordpress网站不安全网络营销的特点有哪些特点
  • 从零开始做网站seo营销策划方案内容
  • 关于建设小康社会的网站百度竞价排名软件
  • 开发公司招商引资产生账务怎么做账杭州关键词推广优化方案
  • 企业网站的可信度建设包括网店运营推广方案
  • 本地宁波网站建设seo工作前景如何
  • 惠州网站建设教程怎么申请域名建立网站
  • 苹果手机建网站百度人工服务24小时热线电话