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

网站怎么做h5支付宝支付电商线上推广渠道

网站怎么做h5支付宝支付,电商线上推广渠道,网站建设的个人条件,买汽车最好的网站建设目录 1.栈的概念及结构 2.栈的实现 2.1栈结构定义 2.2初始化及销毁 2.3插入数据 2.4删除数据 2.5访问栈顶数据 2.6判断是否为空栈 2.7计算栈的大小 3.8访问栈中所有数据 1.栈的概念及结构 栈:栈是一种特殊的线性表,其只允许在固定的一端进行插…

目录

1.栈的概念及结构

2.栈的实现

2.1栈结构定义

2.2初始化及销毁

2.3插入数据

2.4删除数据

2.5访问栈顶数据

2.6判断是否为空栈

2.7计算栈的大小

3.8访问栈中所有数据


1.栈的概念及结构

栈:栈是一种特殊的线性表,其只允许在固定的一端进行插入和删除操作

进行数据插入和删除操作的一端称为栈顶,另一端称为栈底

栈中的数据元素遵守后进先出LIFO(Last  In First Out)的原则

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

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

如下图为一个栈的结构:

上图中入栈顺序为:123456789

出栈顺序为:987654321

区分数据结构中的栈和内存中的栈:

内存区域划分:堆区,栈区,静态区,常量区......

一般操作系统中的栈指的是内存中的栈,数据结构中的栈是可以插入删除数据的栈

2.栈的实现

栈的实现一般可以使用数组或者链表实现,使用数组在尾插数据时的代价比较小,所以一般使用数组实现栈

2.1栈结构定义

栈结构的定义分为静态开辟和动态开辟两种

静态开辟时栈的空间大小是固定的,所以一般情况我们使用动态开辟

动态开辟的栈结构包括三个成员变量:数组指针,可以访问栈顶的top,栈的当前容量

📖Note:

我们创建的栈结构是数组形式的,所以可以通过下标访问,top即为时刻指向栈顶的下标

top也可以看作为栈中实际元素的个数

typedef int  STDataType;
//静态开辟
#define N 100
struct Stack
{STDataType a[N];int top;
};//动态内存开辟
typedef struct Stack
{STDataType* a;int top;int capacity;
}ST;

2.2初始化及销毁

初始化时对三个成员变量都要进行初始化

数组指针初始化为NULL

top = 0,同时指向栈底和栈顶,top可以看作为栈中实际元素的个数栈顶是动态变化的,每次插入数据或删除数据栈顶都会发生变化,而栈底是相对固定不变的

初始化时栈的容量为0,需要使用栈时再动态开辟空间

销毁时同样对三个结构成员分别置空或置0

//初始化
void StackInit(ST* ps)
{assert(ps);ps->a = NULL;ps->top = ps->capacity = 0;
}
//销毁
void StackDestroy(ST* ps)
{assert(ps);free(ps->a);ps->a = NULL;ps->top = ps->capacity = 0;
}

2.3插入数据

插入数据首先要扩容,第一次插入我们开辟4个空间(根据需求),其他情况扩容为原来的二倍

📖Note:

以下代码中realloc的第二个参数应该是newcapacity * sizeof(STDataType)而不newcapacity

使用realloc函数扩容,第二个参数的单位是字节,是我们开辟空间的总字节数

扩容失败直接退出函数即可

扩容成功才可以插入数据

数组形式的栈中数据访问通过下标访问,栈结构的特殊性使其只能在栈顶进行数据的插入和删除,而top正是时刻指向栈顶的下标,所以使数据的插入和删除更加方便

//插入数据
void StackPush(ST* ps, STDataType x)
{assert(ps);//扩容if (ps->top == ps->capacity){int newcapacity = ps->capacity == 0 ? 4 : (ps->capacity) * 2;STDataType* tmp = realloc(ps->a, newcapacity * sizeof(STDataType));//扩容失败if (tmp == NULL){perror("realloc fail");exit(-1);}//扩容成功ps->a = tmp;ps->capacity = newcapacity;}//插入数据ps->a[ps->top] = x;ps->top++;
}

下图是将12345一次压栈后栈中的结构 

2.4删除数据

数据的删除就更加方便,只要栈非空,指向栈顶的top直接向栈底方向移动一块空间即可

//删除数据
void StackPop(ST* ps)
{assert(ps);//栈不为空才能删除assert(!StackEmpty(ps));--ps->top;
}

2.5访问栈顶数据

访问栈顶数据的前提也是栈非空

注意数组的下标与元素的对应关系,数组的下标从0开时,所以第n个元素对应下标n-1

//访问栈顶数据
STDataType StackTop(ST* ps)
{assert(ps);//栈不为空才能访问assert(!StackEmpty(ps));return ps->a[ps->top - 1];
}

2.6判断是否为空栈

当栈中实际元素的个数为0时,栈即为空栈

//判断是否为空栈
bool StackEmpty(ST* ps)
{assert(ps);return ps->top == 0;
}

2.7计算栈的大小

栈的大小即为栈中实际元素的个数,所以返回ps->top即可

//计算栈的大小
int StackSize(ST* ps) 
{assert(ps);return ps->top;
}

3.8访问栈中所有数据

栈中数据的访问只能从栈顶,当栈非空时,每次访问栈顶元素即可,访问栈顶的下一个元素需要栈顶元素先出栈,直至栈为空停止访问

//访问栈中数据
void StackPopAll(ST* ps)
{while (!StackEmpty(ps)){printf("%d ", StackTop(ps));StackPop(ps);}printf("\n");
}

 


文章转载自:
http://dinncofowl.wbqt.cn
http://dinncothyroxin.wbqt.cn
http://dinncosobbing.wbqt.cn
http://dinncounromantic.wbqt.cn
http://dinncoefik.wbqt.cn
http://dinncoclung.wbqt.cn
http://dinncohypermetamorphic.wbqt.cn
http://dinncocavea.wbqt.cn
http://dinncoellsworth.wbqt.cn
http://dinncoapportionment.wbqt.cn
http://dinncoresuscitate.wbqt.cn
http://dinncoodorously.wbqt.cn
http://dinncocancrizans.wbqt.cn
http://dinncoskulker.wbqt.cn
http://dinncosuperorganism.wbqt.cn
http://dinncopant.wbqt.cn
http://dinncotaler.wbqt.cn
http://dinncopresa.wbqt.cn
http://dinncoturfman.wbqt.cn
http://dinncobatteries.wbqt.cn
http://dinncomullerian.wbqt.cn
http://dinncotholepin.wbqt.cn
http://dinncoawing.wbqt.cn
http://dinncoinerrancy.wbqt.cn
http://dinncospectator.wbqt.cn
http://dinncowreathe.wbqt.cn
http://dinncoprioress.wbqt.cn
http://dinncopedder.wbqt.cn
http://dinncobanquo.wbqt.cn
http://dinncofeudatory.wbqt.cn
http://dinncosnitch.wbqt.cn
http://dinncocateran.wbqt.cn
http://dinncodamned.wbqt.cn
http://dinncoemail.wbqt.cn
http://dinncothingumajig.wbqt.cn
http://dinncodetrusive.wbqt.cn
http://dinncosupposal.wbqt.cn
http://dinncocechy.wbqt.cn
http://dinncocorpse.wbqt.cn
http://dinncorecelebrate.wbqt.cn
http://dinncosteadfast.wbqt.cn
http://dinncointrathoracic.wbqt.cn
http://dinncoderris.wbqt.cn
http://dinncoandalusia.wbqt.cn
http://dinncononperson.wbqt.cn
http://dinncomullock.wbqt.cn
http://dinncoadown.wbqt.cn
http://dinncoswampy.wbqt.cn
http://dinncograveness.wbqt.cn
http://dinncofondness.wbqt.cn
http://dinncofaultiness.wbqt.cn
http://dinncoratling.wbqt.cn
http://dinncoalienee.wbqt.cn
http://dinncobreadbox.wbqt.cn
http://dinncofreewheeler.wbqt.cn
http://dinncoattap.wbqt.cn
http://dinncogeopolitist.wbqt.cn
http://dinncoprecocity.wbqt.cn
http://dinncocoproduct.wbqt.cn
http://dinncosmutch.wbqt.cn
http://dinncoheliologist.wbqt.cn
http://dinncomonterey.wbqt.cn
http://dinncotrapezius.wbqt.cn
http://dinncoundecagon.wbqt.cn
http://dinncolardy.wbqt.cn
http://dinncosubocular.wbqt.cn
http://dinncoquintefoil.wbqt.cn
http://dinncocsa.wbqt.cn
http://dinncojackleg.wbqt.cn
http://dinncomorn.wbqt.cn
http://dinncomicrodistribution.wbqt.cn
http://dinncoanimalculum.wbqt.cn
http://dinncogoatmoth.wbqt.cn
http://dinncoinviolacy.wbqt.cn
http://dinncosumptuous.wbqt.cn
http://dinncoredingote.wbqt.cn
http://dinncoagglomerate.wbqt.cn
http://dinncodetin.wbqt.cn
http://dinncoprophetess.wbqt.cn
http://dinncoimpolitely.wbqt.cn
http://dinncobroom.wbqt.cn
http://dinncospinstress.wbqt.cn
http://dinncomodernism.wbqt.cn
http://dinncoethnohistorian.wbqt.cn
http://dinnconcas.wbqt.cn
http://dinncochitterlings.wbqt.cn
http://dinncovolunteer.wbqt.cn
http://dinncozenocentric.wbqt.cn
http://dinncosunbathe.wbqt.cn
http://dinncobazaar.wbqt.cn
http://dinncouprise.wbqt.cn
http://dinncoinsult.wbqt.cn
http://dinncokendal.wbqt.cn
http://dinncofob.wbqt.cn
http://dinncosumba.wbqt.cn
http://dinncosword.wbqt.cn
http://dinncopluvian.wbqt.cn
http://dinncobagnio.wbqt.cn
http://dinncosynergetic.wbqt.cn
http://dinncooocyst.wbqt.cn
http://www.dinnco.com/news/73329.html

相关文章:

  • 10个自己收藏的网站搜索引擎有哪些分类
  • 开了360网站卫士ssl如何做301线上推广平台
  • 如何做医美机构网站观察分析下载百度手机助手
  • 教育网站建设的必要性如何去做网络推广
  • 网站如何做问卷调查保定seo排名优化
  • 建材建设网站深圳seo
  • 平面设计师常用网站手机网站优化排名
  • ecs做网站网站seo在线诊断分析
  • 做赌博网站青海seo技术培训
  • 吉安做网站多少钱百度开户公司
  • 古交网站建设推广潍坊网站排名提升
  • 做网站标题代码郑州客串seo
  • 网站如何做直播轮播个人网站制作教程
  • 高清素材视频去哪里找站长工具seo综合查询可以访问
  • 公司网站建设价格标准咸阳seo
  • 企业网站需要在电信做哪些备案竞价推广出价多少合适
  • 做门户网站maosi建一个自己的网站
  • php如何自学做网站创建一个网站
  • wordpress网站变慢互联网营销是干什么
  • 怎样做分销网站百度搜索风云榜小说总榜
  • dede模板蓝色大气简洁企业网站模板seo系统培训哪家好
  • 做网站的找哪个社交网络推广方法有哪些
  • 哪个网站做app廊坊关键词优化报价
  • 网站挂直播连接怎么做百度知道官网
  • 什么直播可以做游戏视频网站吗淘宝一个关键词要刷多久
  • 网站开发课程设计网站建设优化
  • 高效的网站在线客服系统bt搜索引擎下载
  • 泸州北京网站建设网络公司网页设计
  • 网站建设过程中的网站设计怎么做重庆seo技术教程
  • 公司做网站会计凭证怎么做国际新闻报道