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

wordpress登录密码忘北京seo优化排名

wordpress登录密码忘,北京seo优化排名,网站用ps下拉效果怎么做的,怎么查看网站是哪家公司做的栈的基本概念 1. 栈的定义:只允许在一端进行插入或删除操作的线性表(可以理解为操作受限的线性表)。 2. 栈的特点:后进先出(LIFO)。 3. 栈的基本操作:初始化、销毁、进栈、出栈、读栈顶元素等…

栈的基本概念

1. 栈的定义:只允许在一端进行插入或删除操作的线性表(可以理解为操作受限的线性表)。

2. 栈的特点:后进先出(LIFO)。

3. 栈的基本操作:初始化、销毁、进栈、出栈、读栈顶元素等。

InitStack(&S):初始化栈。构造一个空栈 S,分配内存空间。
DestroyStack(&S):销毁栈。销毁并释放栈 S 所占用的内存空间。
Push(&S,x):进栈,若栈S未满,则将x加入使之成为新栈顶。
Pop(&S,&x):出栈,若栈S非空,则弹出栈顶元素,并用x返回。
GetTop(S, &x):读栈顶元素。若栈 S 非空,则用 x 返回栈顶元素
StackEmpty(S):判断一个栈 S 是否为空。若S为空,则返回true,否则返回false。 

栈的常考题型:进栈顺序与出栈顺序的关系。

n个不同的元素进栈,出栈元素不同排列的个数为\frac{1}{n+1}\textrm{C}_{2n}^{n}

栈的顺序存储实现(顺序栈)

顺序存储:给各个数据元素分配连续的存储空间,大小为MaxSize*sizeof(ElemType)。

顺序栈的定义

#define MaxSize 10 //定义栈中元素的最大个数
typedef struct{ElemType data[MaxSize]; //静态链表中存放栈中元素int top; //指向栈顶元素
} SqStack;

我们通过top的值指向栈顶元素,即top的范围数组索引值[0,n-1]。因此如果栈是空栈,就令top=-1。

顺序栈的初始化与判断栈空

void InitStack(SqStack &S){S.top==-1; //初始化栈顶指针
}
bool StackEmpty(SqStack S){if(S.top==-1)return true;elsereturn false;
}

新元素入栈

bool PushStack(SqStack &S,ElemType x){if(S.top==MaxSize-1) //判断是否满栈return false;S.data[++S.top]==x;return true;
}

由于S.top是索引指向当前的栈顶位置,因此S.data[++S.top]==x,而不是S.data[S.top++]==x。对于后者我们可以采取另一种方式——让top指向下一个可以插入的位置,这时需要将top初始化为0,判断栈满的条件也变成了:top==MaxSize。

出栈

bool PopStack(SqStack &S,ElemType &x){if(S.top==-1) //栈空,报错return false;x=S.data[S.top--];return true;
}

读取栈顶元素

bool GetTop(SqStack S,ElemType &x){if(S.top==-1)return false;x=S.data[S.top]; //记录栈顶元素,引用返回return true;
}

顺序栈的缺点:栈的大小不可变。

共享栈

共享栈:两个栈共享同一片存储空间,这片存储空间不单独属于任何一个栈,某个栈需要的多一点,它就可能得到更多的存储空间;
两个栈的栈底在这片存储空间的两端,当元素入栈时,两个栈的栈顶指针相向而行。

栈满的条件:top0+1=top1;(top是int类型,是数组的索引值)

#define MaxSize 10
typedef struct{ElemType data[MaxSize];int top0; //0号栈栈顶指针int top1; //1号栈栈顶指针
} ShStack;
void InitStack(ShStack &S){S.top0=-1;S.top1=MaxSize;
}

链栈

1. 栈的链式存储实现通过单链表模拟,进栈采用头插法。

2. 出栈操作对应单链表的删除操作,需对头结点进行“后删”处理。

3. 链栈定义及初始化,带头结点的链栈便于操作。

#include<stdlib.h>
#include<stdio.h>#define MAXSIZE 10typedef int ElemType;typedef struct Linknode {ElemType data;struct Linknode*next;
}*LiStack;

带头结点的链栈

//初始化
void InitLiStack(LiStack &s){s=(Linknode*)malloc(sizeof(Linknode));if(s==NULL){printf("内存分配失败!\n");return ;}s->next=NULL;printf("空间申请成功!\n");
} //销毁
void DestryLiStack(LiStack &s){Linknode* p=s->next;while(p!=NULL){Linknode* r=p;p->next=r->next;free(r);}free(s);printf("销毁成功!\n");
} //入栈
void PushLiStack(LiStack &s,ElemType e){Linknode* r=(Linknode*)malloc(sizeof(Linknode));r->data=e;r->next=s->next;s->next=r;printf("插入节点成功!\n"); 
} //出栈
void PopLiStack(LiStack &s,ElemType &e){if(s->next==NULL){printf("栈空!\n");return;}Linknode* p=s->next;e=p->data;s->next=p->next;free(p);printf("出栈成功!\n"); 
} //获取栈顶节点
Linknode* GetElem(LiStack &s,ElemType &e){if(s->next==NULL){printf("栈空!\n");return NULL;}Linknode* p=s->next;e=p->data;
} 

不带头结点的链栈

//初始化
void InitLiStack(LiStack &s){s=NULL;printf("申请空间成功!\n"); 
} //销毁
void DestryLiStack(LiStack&s){Linknode* p=s;while(p->next!=NULL){Linknode* r=p;p=r->next;free(r);}//最后一个节点特殊处理free(p); printf("销毁成功!\n");
} //入栈
void PushLiStack(LiStack &s,ElemType e){//如果开始没有节点,特殊处理 if(s==NULL){Linknode* r=(Linknode*)malloc(sizeof(Linknode));r->data=e;r->next=NULL;s=r;printf("插入节点成功!\n"); return ; } Linknode* r=(Linknode*)malloc(sizeof(Linknode));//首先将头结点的值修改为要插入的值e,将r->data=s->data,最后直接在头结点后面插入节点r即可 r->data=s->data;s->data=e;r->next=s->next;s->next=r;printf("插入节点成功!\n"); 
} //出栈
void PopLiStack(LiStack &s,ElemType &e){if(s==NULL){printf("栈空!\n");return;}//只有一个节点的时候特殊处理 if(s->next==NULL){e=s->data; free(s);return ;} Linknode* p=s;e=p->data;s->next=p->next;free(p);printf("出栈成功!\n"); 
} //获取栈顶节点
Linknode* GetElem(LiStack &s,ElemType &e){if(s==NULL){printf("栈空!\n");return NULL;}Linknode* p=s;e=p->data;
} 
http://www.ds6.com.cn/news/31433.html

相关文章:

  • 最高法律网站是做啥的seo排名优化课程
  • 湖北阳新县建设局网站找网站公司制作网站
  • 电商网站制作成手机appvi设计
  • b站看男女深圳关键词优化
  • 网站维护具体做啥seo快速排名网站优化
  • 产品展示型网站seo项目分析
  • 网站注册页面怎么做数据验证码站长工具友链检测
  • 给公司做网站需要多少钱百度知道官网
  • 合肥做网站推荐 晨飞网络希爱力的功效及副作用
  • 网站和网址有什么不同网站每天做100个外链
  • webui界面西安网站优化公司
  • wordpress成品网站免费seo网址优化靠谱
  • 个人可以建网站网站优化最为重要的内容是
  • 做一元购网站会被封吗海外营销
  • 在哪个网站做淘宝水印雅虎搜索引擎中文版
  • 南阳网站设计深圳seo网络优化公司
  • 宁波制作网站公司谷歌海外广告投放推广
  • 做网站好的公司开封网站设计
  • 网站建设最新外文翻译英文seo
  • 电子商城网站朋友圈广告推广
  • 重庆网站建设找重庆万为济南做seo外包
  • 网站接入服务器商查询指数函数公式
  • 吉林市网站创意与建设网站搭建谷歌seo
  • 镇江网站建设yubei021引流推广平台有哪些
  • 精品资源共享课程网站建设论文快速seo排名优化
  • 怎样搭建微网站排名前十的小说
  • 南昌商城网站建设无锡网站制作优化
  • 做网站开发赚钱吗一级域名生成二级域名
  • 网站怎么做框架集网络优化
  • 班级网站做哪些方面营销手段