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

十大免费ppt网站在线网站自己做服务器划算吗

十大免费ppt网站在线,网站自己做服务器划算吗,装修设计软件酷家乐,做编程题的网站栈的接口实现(附图解和源码) 文章目录栈的接口实现(附图解和源码)前言一、定义结构体二、接口实现(附图解源码)1.初始化栈2.销毁栈3.入栈4.判断栈是否为空5.出栈6.获取栈顶元素7.获取栈中元素个数三、源代码…

栈的接口实现(附图解和源码)


文章目录

  • 栈的接口实现(附图解和源码)
  • 前言
  • 一、定义结构体
  • 二、接口实现(附图解+源码)
    • 1.初始化栈
    • 2.销毁栈
    • 3.入栈
    • 4.判断栈是否为空
    • 5.出栈
    • 6.获取栈顶元素
    • 7.获取栈中元素个数
  • 三、源代码展示
    • (1)test.c(测试+主函数)
    • (2)Stack.h(接口函数的声明)
    • (3)Stack.c(接口函数的实现)
  • 总结


前言

本文主要介绍双向链表中增删查改等接口实现,结尾附总源码!这里我们采用数组栈的方式。


一、定义结构体

在这里插入图片描述


二、接口实现(附图解+源码)

在这里插入图片描述
这里一共7个接口,我会我都会一 一为大家讲解(图解+源码


1.初始化栈

这里初始化和顺序表一样,详细的可以参考顺序表
在这里插入图片描述

代码如下(示例):

void StackInit(ST* ps)
{assert(ps);ps->a = NULL;ps->top = ps->capacity = 0;
}

2.销毁栈

销毁栈也可以直接参考顺序表,在这里不做过多介绍!

代码如下(示例):

void StackDestroy(ST* ps)
{assert(ps);free(ps->a);ps->a = NULL;ps->capacity = ps->top = 0;
}

3.入栈

这里要考虑增容的问题:
在这里插入图片描述

代码如下(示例):

void StackPush(ST* ps, STDataType x)
{assert(ps);if (ps->top == ps->capacity){int newCapacity = ps->capacity == 0 ? 4 : ps->capacity * 2;STDataType* tmp = (STDataType*)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++;
}

4.判断栈是否为空

如果ps->top=0即栈为空!这里也可以用if语句,我这里是直接返回 true of false

代码如下(示例):

bool StackEmpty(ST* ps)
{assert(ps);return ps->top == 0;
}

5.出栈

这里要注意:需要用 StackEmpty 判断一下栈是否为空,因为空了之后就不需要出栈!
在这里插入图片描述

代码如下(示例):

void StackPop(ST* ps)
{assert(ps);assert(!StackEmpty(ps));--ps->top;
}

6.获取栈顶元素

这里也要注意:需要用 StackEmpty 判断一下栈是否为空,因为空了之后就不可以获取栈顶元素!


在这里插入图片描述我初始化时 top 用的0,所以在获取栈顶数据时,直接 ps->a[ps->top - 1]

代码如下(示例):

STDataType StackTop(ST* ps)
{assert(ps);assert(!StackEmpty(ps));return ps->a[ps->top - 1];
}

7.获取栈中元素个数

直接返回 top 即可,这里不做过多的介绍!

代码如下(示例):

int StackSize(ST* ps)
{assert(ps);return ps->top;
}

三、源代码展示

(1)test.c(测试+主函数)

代码如下(示例):

//#include <stdio.h>
//
//int f(int n)
//{
//	return n == 1 ? 1 : f(n - 1) + n;
//}
//
//int main()
//{
//	printf("%d\n", f(10000));
//	
//	return 0;
//}
#include <stdio.h>
#include "Stack.h"
#include "Queue.h"
// 解耦 -- 低耦合 高内聚
// 数据结构建议不要直接访问结构数据,一定要通过函数接口访问
void TestStack()
{ST st;StackInit(&st);StackPush(&st, 1);StackPush(&st, 2);StackPush(&st, 3);printf("%d ", StackTop(&st));StackPop(&st);printf("%d ", StackTop(&st));StackPop(&st);StackPush(&st, 4);StackPush(&st, 5);while (!StackEmpty(&st)){printf("%d ", StackTop(&st));StackPop(&st);}printf("\n");
}
void TestQueue()
{Queue q;QueueInit(&q);QueuePush(&q, 1);QueuePush(&q, 2);QueuePush(&q, 3);printf("%d ", QueueFront(&q));QueuePop(&q);printf("%d ", QueueFront(&q));QueuePop(&q);QueuePush(&q, 4);QueuePush(&q, 4);QueuePush(&q, 4);while (!QueueEmpty(&q)){printf("%d ", QueueFront(&q));QueuePop(&q);}printf("\n");QueueDestroy(&q);
}
int main()
{//TestStack();TestQueue();return 0;
}

(2)Stack.h(接口函数的声明)

代码如下(示例):

#pragma once
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <stdbool.h>
//#define N 100
//typedef int STDataType;
//struct Stack
//{
//	STDataType a[N];
//	int top;
//};
typedef int STDataType;
typedef struct Stack
{STDataType* a;int top;int capacity;
}ST;void StackInit(ST* ps);//初始化栈
void StackDestroy(ST* ps);//销毁
void StackPush(ST* ps, STDataType x);//入栈
void StackPop(ST* ps);//出栈
STDataType StackTop(ST* ps);//获取栈顶元素
bool StackEmpty(ST* ps);//检测栈是否为空
int StackSize(ST* ps);//获取栈中有效元素个数

(3)Stack.c(接口函数的实现)

代码如下(示例):

#include "Stack.h"
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->capacity = ps->top = 0;
}
void StackPush(ST* ps, STDataType x)
{assert(ps);if (ps->top == ps->capacity){int newCapacity = ps->capacity == 0 ? 4 : ps->capacity * 2;STDataType* tmp = (STDataType*)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++;
}
void StackPop(ST* ps)
{assert(ps);assert(!StackEmpty(ps));--ps->top;
}
STDataType StackTop(ST* ps)
{assert(ps);assert(!StackEmpty(ps));return ps->a[ps->top - 1];
}
bool StackEmpty(ST* ps)
{assert(ps);return ps->top == 0;
}
int StackSize(ST* ps)
{assert(ps);return ps->top;
}

总结

以上就是今天要讲的内容,本文介绍栈的接口实现(附图解和源码)!
如果我的博客对你有所帮助记得三连支持一下,感谢大家的支持!
在这里插入图片描述

http://www.yayakq.cn/news/454168/

相关文章:

  • 网站rar文件建设有限公司首页
  • 攻击网站方法申请建设网站经费申请
  • 陕西省建设建设监理协会网站张槎网站开发
  • 做盗版网站会坐牢吗手机网站打开速度
  • 公司起名字大全免费测分1518淄博网站制作升级优化
  • 网站交换链接的网络营销意义长沙百度网站优化
  • 东莞网站开发哪里找php网站程序怎么安装
  • 旅游网官方网站青岛网站seo多少钱
  • 网站开发工程师swot分析怎样做网站后台运营
  • 马鞍山市重点工程建设管理局网站建设网站的新闻
  • 网站ipc备案浙江省交通建设工程监督管理局网站
  • 湛江的网站互联网行业公司
  • 做网站负责人有法律风险吗彩票网站招代理广告怎么做
  • 外贸公司英文网站建设建设网站龙华
  • 网站链接可以自己做吗中山中小企业网站制作
  • 沈阳有做网站的吗装修公司口碑好的公司
  • 公司部门优化营商环境心得体会
  • wordpress 网站静态wordpress考试主题
  • 淘宝网站建设的特点wordpress固定链接标签加上页面
  • 网站精神文件建设专栏长沙影楼网站建设
  • 做it的网站有哪些公司网站建设东莞
  • 网站的服务与建设岗位职责网站建设的发展前景
  • mvc 网站开发工业设计手绘
  • 做网站有哪些程序互联网网站建设哪里好
  • 百度排名 网站标题怎样说服企业做网站建设推广
  • 浪琴女士手表网站珠海市官网网站建设价格
  • 网站排名怎么做上去wordpress 移动端优势
  • 网站做百度竞价的标志最新招总代理项目
  • 服务器做ssr后还可以做网站吗华夏名网
  • 个人或企业做网络贸易的主要网站asp网站qq登录