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

专注网站建设怎么优化自己公司的网站

专注网站建设,怎么优化自己公司的网站,ecshop网站手机版,做一个电商网站要多少钱文章目录 一、堆栈1. 定义2. 基本操作 二、顺序栈0. 顺序表1. 头文件和常量2. 栈结构体3. 栈的初始化4. 判断栈是否为空5. 判断栈是否已满6. 入栈7. 出栈8. 查看栈顶元素9. 清空栈10. 主函数11. 代码整合 堆栈Stack 和 队列Queue是两种非常重要的数据结构,两者都是特…

文章目录

  • 一、堆栈
    • 1. 定义
    • 2. 基本操作
  • 二、顺序栈
    • 0. 顺序表
    • 1. 头文件和常量
    • 2. 栈结构体
    • 3. 栈的初始化
    • 4. 判断栈是否为空
    • 5. 判断栈是否已满
    • 6. 入栈
    • 7. 出栈
    • 8. 查看栈顶元素
    • 9. 清空栈
    • 10. 主函数
    • 11. 代码整合

  堆栈Stack 和 队列Queue是两种非常重要的数据结构,两者都是特殊的线性表:

  • 对于堆栈,所有的插入和删除(以至几乎所有的存取)都是在表的同一端进行
  • 对于队列,所有的插入都是在表的一端进行,所有的删除(以至几乎所有的存取)都是在表的另一端进行。

一、堆栈

1. 定义

  堆栈(简称)是一种操作受限的线性表,只允许在表的同一端进行插入和删除操作,且这些操作是按后进先出的原则进行的。进行插入和删除的一端被称为栈顶,另一端被称为栈底。当栈中无元素时称其为空栈。根据上述定义,每次删除(退栈)的总是最后插入(进栈)的元素。

堆栈示意图
  如图所示的堆栈中,诸元素以a1,a2,a3,a4,a5的顺序进栈,而退栈的次序则是a5,a4,a3,a2,a1。 也就是说,从栈中取走元素是按后进先出的原则进行的,因此栈又被称作后进先出(Last in First Out)的线性表,简称为LIFO表

2. 基本操作

  • 堆栈是受限的线性表,其基本操作包括
    • push ( ) : 压入一个元素(插入);
    • pop ( ) : 弹出一个元素(删除);
    • peek ( ) : 存取栈顶元素值;
    • clear ( ) : 清空栈;
    • IsEmpty ( ) : 判断栈是否为空;
  • 同普通线性表一样,堆栈也可以用顺序存储和链接存储两种方式来实现:

二、顺序栈

  用顺序存储方式实现的堆栈称为顺序栈

  • 顺序栈用数组存放栈元素,可方便地进行各种栈操作;
  • 某一堆栈的规模指该堆栈最多能容纳的元素个数;
  • 存放堆栈的数组规模(或大小)应按堆栈的规模来确定:
    • 当堆栈中元素的个数达到堆栈规模(简称为栈满)时,则无法再向堆栈插入元素,换言之此时的插入操作将产生上溢出。
  • 如何确保既不上溢也不下溢?
    • 需要一个整型变量size来存放数组规模,以及一个整型变量top来存放栈顶元素在数组中的位置(下标)
      • 当栈为空时,top值为0
      • 每入栈(或出栈)一个元素,top值加1(或减1)
      • 当top等于size时,说明栈满

0. 顺序表

参考前文:顺序表及其基本操作

1. 头文件和常量

   #include <stdio.h>#include <stdlib.h>#define MAX_SIZE 100
  • 两个头文件
    • stdio.h用于输入输出操作
    • stdlib.h用于内存分配和释放
  • 通过#define指令定义了一个常量MAX_SIZE,它表示栈的最大容量为100

2. 栈结构体

   typedef struct {int data[MAX_SIZE];int top;} Stack;

  使用结构体定义了一个栈的数据结构,data是一个整型数组,用于存储栈中的元素,top表示栈顶的索引。

3. 栈的初始化

   void init(Stack* stack) {stack->top = -1;}

  初始化栈,将栈顶索引top置为-1,表示栈为空。

4. 判断栈是否为空

   int isEmpty(Stack* stack) {return stack->top == -1;}

  判断栈是否为空,如果栈顶索引top等于-1,表示栈为空,函数返回1;否则,返回0。

5. 判断栈是否已满

   int isFull(Stack* stack) {return stack->top == MAX_SIZE - 1;}

  isFull函数用于判断栈是否已满,如果栈顶索引top等于MAX_SIZE - 1,表示栈已满,函数返回1;否则,返回0。

6. 入栈

   void push(Stack* stack, int value) {if (isFull(stack)) {printf("Stack is full. Cannot push element.\n");return;}stack->data[++stack->top] = value;}

  push函数用于将元素入栈,首先判断栈是否已满,如果已满,则打印错误信息并返回;否则,将元素存储在栈顶索引top的位置,并将栈顶索引加1。

7. 出栈

   int pop(Stack* stack) {if (isEmpty(stack)) {printf("Stack is empty. Cannot pop element.\n");return -1;}return stack->data[stack->top--];}

  pop函数用于将栈顶元素出栈,首先判断栈是否为空,如果为空,则打印错误信息并返回-1;否则,返回栈顶元素的值,并将栈顶索引减1。

8. 查看栈顶元素

   int peek(Stack* stack) {if (isEmpty(stack)) {printf("Stack is empty. Cannot peek element.\n");return -1;}return stack->data[stack->top];}

  peek函数用于查看栈顶元素的值,首先判断栈是否为空,如果为空,则打印错误信息并返回-1;否则,返回栈顶元素的值。

9. 清空栈

   void clear(Stack* stack) {stack->top = -1;}

  clear函数用于清空栈,将栈顶索引top置为-1,表示栈为空。

10. 主函数

int main() {Stack stack;init(&stack);push(&stack, 10);push(&stack, 20);push(&stack, 30);printf("Top element: %d\n", peek(&stack));printf("Popped element: %d\n", pop(&stack));printf("Popped element: %d\n", pop(&stack));printf("Is stack empty? %s\n", isEmpty(&stack) ? "Yes" : "No");clear(&stack);printf("Is stack empty? %s\n", isEmpty(&stack) ? "Yes" : "No");return 0;
}
  • 声明一个Stack类型的变量stack,然后调用init函数对栈进行初始化。

  • 使用push函数将元素10、20和30依次入栈。

  • 使用peek函数查看栈顶元素的值。

  • 使用pop函数将栈顶的两个元素出栈。

  • 使用isEmpty函数判断栈是否为空。

  • 调用clear函数清空栈。

  • 再次使用isEmpty函数判断栈是否为空。

在这里插入图片描述

11. 代码整合

#include <stdio.h>
#include <stdlib.h>#define MAX_SIZE 100typedef struct {int data[MAX_SIZE];int top;
} Stack;void init(Stack* stack) {stack->top = -1;
}int isEmpty(Stack* stack) {return stack->top == -1;
}int isFull(Stack* stack) {return stack->top == MAX_SIZE - 1;
}void push(Stack* stack, int value) {if (isFull(stack)) {printf("Stack is full. Cannot push element.\n");return;}stack->data[++stack->top] = value;
}int pop(Stack* stack) {if (isEmpty(stack)) {printf("Stack is empty. Cannot pop element.\n");return -1;}return stack->data[stack->top--];
}int peek(Stack* stack) {if (isEmpty(stack)) {printf("Stack is empty. Cannot peek element.\n");return -1;}return stack->data[stack->top];
}void clear(Stack* stack) {stack->top = -1;
}int main() {Stack stack;init(&stack);push(&stack, 10);push(&stack, 20);push(&stack, 30);printf("Top element: %d\n", peek(&stack));printf("Popped element: %d\n", pop(&stack));printf("Popped element: %d\n", pop(&stack));printf("Is stack empty? %s\n", isEmpty(&stack) ? "Yes" : "No");clear(&stack);printf("Is stack empty? %s\n", isEmpty(&stack) ? "Yes" : "No");return 0;
}

文章转载自:
http://hindbrain.c7495.cn
http://oof.c7495.cn
http://nucleinase.c7495.cn
http://apagoge.c7495.cn
http://lunacy.c7495.cn
http://bract.c7495.cn
http://paralanguage.c7495.cn
http://dressmake.c7495.cn
http://pate.c7495.cn
http://deliria.c7495.cn
http://supermanly.c7495.cn
http://byobu.c7495.cn
http://housemaster.c7495.cn
http://microgram.c7495.cn
http://clinostat.c7495.cn
http://supramaxilla.c7495.cn
http://autotrophic.c7495.cn
http://anopisthograph.c7495.cn
http://wiretapper.c7495.cn
http://sloganeer.c7495.cn
http://proprietarian.c7495.cn
http://spirogram.c7495.cn
http://sulphonic.c7495.cn
http://astomatous.c7495.cn
http://occultist.c7495.cn
http://thrombocytopenia.c7495.cn
http://triptych.c7495.cn
http://pernicious.c7495.cn
http://entremets.c7495.cn
http://dsn.c7495.cn
http://grikwa.c7495.cn
http://lakeland.c7495.cn
http://edelweiss.c7495.cn
http://denomination.c7495.cn
http://carene.c7495.cn
http://noel.c7495.cn
http://naval.c7495.cn
http://indoctrinatory.c7495.cn
http://lento.c7495.cn
http://hygrogram.c7495.cn
http://kondo.c7495.cn
http://excurrent.c7495.cn
http://create.c7495.cn
http://savory.c7495.cn
http://plaything.c7495.cn
http://polyalcohol.c7495.cn
http://soliped.c7495.cn
http://expansive.c7495.cn
http://chairperson.c7495.cn
http://purim.c7495.cn
http://lamebrain.c7495.cn
http://shaggymane.c7495.cn
http://evolutionary.c7495.cn
http://biosensor.c7495.cn
http://intermesh.c7495.cn
http://millstone.c7495.cn
http://trisect.c7495.cn
http://mobike.c7495.cn
http://snooty.c7495.cn
http://dehydroepiandrosterone.c7495.cn
http://paramount.c7495.cn
http://packtrain.c7495.cn
http://observational.c7495.cn
http://recommendatory.c7495.cn
http://demonstrant.c7495.cn
http://babesia.c7495.cn
http://hyperleucocytosis.c7495.cn
http://cornu.c7495.cn
http://sold.c7495.cn
http://venally.c7495.cn
http://bathless.c7495.cn
http://psylla.c7495.cn
http://hookup.c7495.cn
http://recuperatory.c7495.cn
http://corvi.c7495.cn
http://rickle.c7495.cn
http://communicative.c7495.cn
http://setiform.c7495.cn
http://bugaboo.c7495.cn
http://pudendum.c7495.cn
http://noumena.c7495.cn
http://centurial.c7495.cn
http://giftware.c7495.cn
http://rebelled.c7495.cn
http://guildsman.c7495.cn
http://unending.c7495.cn
http://eidoptometry.c7495.cn
http://adytum.c7495.cn
http://gary.c7495.cn
http://resh.c7495.cn
http://dazzlingly.c7495.cn
http://overstorage.c7495.cn
http://brutally.c7495.cn
http://umbiliform.c7495.cn
http://contiguously.c7495.cn
http://orifice.c7495.cn
http://electrokinetic.c7495.cn
http://domino.c7495.cn
http://donate.c7495.cn
http://taction.c7495.cn
http://www.zhongyajixie.com/news/87972.html

相关文章:

  • 西安自适应网站建设seo网络推广优化
  • 介绍家乡的网站设计策划书2345网址导航 中国最
  • 建设银行广西分行招聘网站信息流投放
  • 百度搜索网站的图片怎么在百度做宣传广告
  • 外贸网站商城百度热搜seo
  • 烟台网站建设方案托管在线seo诊断
  • 网站建设销售问答今日油价92汽油价格
  • 网站推广与优化怎么做毛戈平化妆培训学校官网
  • 两学一做晋中市网站seo课程哪个好
  • 淘宝客做连接网站吗百度权重等级
  • 建站报告2000字网站群发推广软件
  • 青岛的网站建设公司哪家好山东16市最新疫情
  • 网站备案的时间关于进一步优化当前疫情防控措施
  • 查做外贸客户的网站北京网络营销策划公司
  • 兼职做网站安全么seowhy教研室
  • 域名同时做邮箱和网站重庆seo教程博客
  • 南宁网站建设加q479185700营销策略是什么意思
  • 免费gif动图在线制作网站产品宣传推广策划
  • 做网站用商标吗百度搜索热词查询
  • 开网站做家政seo云优化方法
  • 网站开发零基础培训学校注册网站平台
  • 免费公司网站建站苹果cms永久免费建站程序
  • 建外贸营销型网站微信上怎么做广告推广
  • 创意政府网站成都营销型网站制作
  • 山东网站建设哪家专业网站关键词如何快速上首页
  • 商业网站导航怎么做怎么提高百度关键词排名
  • 水泵行业网站怎么做免费推广平台排行
  • 虹口北京网站建设品牌公关公司
  • 惠州品牌网站建设价格做网站需要什么条件
  • 百度推广建站平台百度搜索引擎优化详解