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

建设嘉陵摩托车官方网站深圳网站建设的

建设嘉陵摩托车官方网站,深圳网站建设的,企业网站可以备案几个,广西住房和建设厅网站一、个人理解栈是线性表的一种衍生#xff0c;和之前的顺序表和链表在插入和删除元素上有较大差异#xff0c;其他基本相同#xff0c;栈是数据只能插入表的尾部#xff08;栈顶#xff09;#xff0c;删除数据时只能删除表的尾部#xff08;栈顶#xff09;数据#…一、个人理解栈是线性表的一种衍生和之前的顺序表和链表在插入和删除元素上有较大差异其他基本相同栈是数据只能插入表的尾部栈顶删除数据时只能删除表的尾部栈顶数据就是大家经常背的顺口溜后入先出。后插入的数据先删除。二、图解这里把数组竖起来了是方便理解看得更清楚。三、名词解释1、出栈、弹栈是一个意思就是把数据从栈顶移除。2、入栈、压栈是一个意思就是把数据从栈顶插入。3、LIFOLAST IN FIRST OUT的简写也就是后进先出的意思。4、顺序栈和链栈实现方式上的不同顺序栈是用数组实现而链栈是用链表实现。5、上溢栈已满但数据还需要继续入栈。上溢一般认为是一种错误因为可能导致数据录入失败或者导致数据录入延时。当是顺序栈时对此情况有两种措施一是抛出错误。二是重新申请新栈把旧栈数据写入到新栈中不推荐比较耗时。6、下溢栈已空但还是要出栈。下溢一般认为是一种结束标志因为并不会有数据上的缺失。四、函数实现1、InitSqStack1用途初始化顺序栈。2源码Status InitSqStack(SqStack* S) {printf(Init SqStack : );JudgeAllNullPointer(S);S-BasePointer (SqElemType*)MyMalloc(sizeof(SqElemType) * SQ_STACK_MAX_SIZE);S-TopPointer S-BasePointer;S-SqStackMaxSize SQ_STACK_MAX_SIZE;printf(OK\n);PrintPretty();return SuccessFlag; }3参数参数名说明S需要初始化的SqStack*类型顺序栈。2、JudgeSqStackIsEmpty1用途判断顺序栈是否为空。当栈顶指针和栈底指针相等时表示栈为空反之非空。2源码Status JudgeSqStackIsEmpty(SqStack* S) {printf(Judge SqStack : );JudgeAllNullPointer(S);if(S-BasePointer S-TopPointer){printf(Empty\n);PrintPretty();return SuccessFlag;}printf(Not Empty\n);PrintPretty();return FailFlag; }3参数参数名说明S需要判断是否为空的SqStack*类型顺序栈。3、GetSqStackLen1用途求顺序栈的长度。栈顶指针减去栈底指针为顺序栈的长度原理为相同类型的指针相减得到字节数它会再除以一个栈类型头文件中的结构体SqElemType的字节长度得到最终的顺序栈的长度。2源码SqStackMaxSizeType GetSqStackLen(SqStack* S) {JudgeAllNullPointer(S);return S-TopPointer - S-BasePointer; }3参数参数名说明S需要求栈长度的SqStack*类型顺序栈。五、测试代码1、SqStack.c#include stdio.h #include string.h #include stdlib.h #include sys/time.h #include SqStack.hvoid PrintPretty() {printf(*********************************\n); }void PrintPretty_V1() {printf(################\n); }void *MyMalloc(size_t size) {void *Result (void *)malloc(size);if(Result NULL){printf(malloc Function Exec Fail , Out Of Memory ,Exit!!!\n);exit(ExceptionExitFlag);}return Result; }void JudgeAllNullPointer(void* P) {if(!P){printf(Pointer Is Null ,Exit !\n);exit(ExceptionExitFlag);} }Status InitSqStack(SqStack* S) {printf(Init SqStack : );JudgeAllNullPointer(S);S-BasePointer (SqElemType*)MyMalloc(sizeof(SqElemType) * SQ_STACK_MAX_SIZE);S-TopPointer S-BasePointer;S-SqStackMaxSize SQ_STACK_MAX_SIZE;printf(OK\n);PrintPretty();return SuccessFlag; }Status JudgeSqStackIsEmpty(SqStack* S) {printf(Judge SqStack : );JudgeAllNullPointer(S);if(S-BasePointer S-TopPointer){printf(Empty\n);PrintPretty();return SuccessFlag;}printf(Not Empty\n);PrintPretty();return FailFlag; }SqStackMaxSizeType GetSqStackLen(SqStack* S) {JudgeAllNullPointer(S);return S-TopPointer - S-BasePointer; }2、SqStack.h#ifndef SqStack_H #define SqStack_H#define InsertDataArrayLen 8 #define SQ_STACK_MAX_SIZE 6#define ExceptionExitFlag -1 #define SuccessFlag 1 #define FailFlag 0 #define StudentNumLen 8 #define StudentNameLen 8typedef int Status; typedef long long int SqStackMaxSizeType;typedef struct SqElemType {char StudentNum[StudentNumLen];char StudentName[StudentNameLen];int StudentScore; }SqElemType;typedef struct {SqElemType* BasePointer;SqElemType* TopPointer;SqStackMaxSizeType SqStackMaxSize; }SqStack;void *MyMalloc(size_t size); void JudgeAllNullPointer(void* P); void PrintPretty(); void PrintPretty_V1();Status InitSqStack(SqStack* S); Status JudgeSqStackIsEmpty(SqStack* S); SqStackMaxSizeType GetSqStackLen(SqStack* S);#endif3、main.c#include stdio.h #include string.h #include stdlib.h #include SqStack.hint main() {//测试数据生成SqElemType *InsertSqElemArray (SqElemType *)MyMalloc(sizeof(SqElemType) * InsertDataArrayLen);int i;for(i0; iInsertDataArrayLen; i){strcpy(InsertSqElemArray[i].StudentNum ,X666);strcpy(InsertSqElemArray[i].StudentName,Sun);InsertSqElemArray[i].StudentScore i 100;}//测试顺序栈SqStack* S (SqStack*)MyMalloc(sizeof(SqStack));InitSqStack(S);JudgeSqStackIsEmpty(S);printf(SqStack Len : %lld\n,GetSqStackLen(S));PrintPretty();//释放内存free(InsertSqElemArray);InsertSqElemArray NULL;return SuccessFlag; }4、makefileCC gcc CFLAG_EXEC -Wall -O3 CFLAG_ALIAS -o RM_COMM rm -rfall : mainmain : $(CC) $(CFLAG_EXEC) SqStack.c main.c $(CFLAG_ALIAS) TestSqStackclean : $(RM_COMM) TestSqStack六、测试结果[gbaseczg2 LinearTable_Stack]$ make clean rm -rf TestSqStack[gbaseczg2 LinearTable_Stack]$ make gcc -Wall -O3 SqStack.c main.c -o TestSqStack[gbaseczg2 LinearTable_Stack]$ ./TestSqStack Init SqStack : OK ********************************* Judge SqStack : Empty ********************************* SqStack Len : 0 *********************************七、顺序栈的应用大家可以参考一下之前写的文章《leecode-C语言实现-20. 有效的括号》里面用到了顺序栈的知识。
http://www.dnsts.com.cn/news/131421.html

相关文章:

  • 松原权威发布wordpress图片优化加速
  • 做化妆品的网站有哪些godaddy wordpress 优惠码
  • 秦皇岛哪里做网站定制网站建设费用预算
  • 全屏企业网站欣赏网站设计与建设
  • 基础的网站建设温州seo全网营销
  • 西双版纳网站建设简体转繁体wordpress插件
  • 婴儿辅食中企动力提供网站建设学校网页网站模板免费下载
  • 找公司做网站怎么图片都要自己找淘宝每平每屋设计家官网
  • 网站建设技能考试试题三培训机构不退费最有效方式
  • 邮箱注册网站申请网站程序结构
  • wordpress全站静态化wordpress 机械
  • 宁波网站推广优化公司门户网站是什么意思?
  • 投稿的网站模板网站什么意思
  • 网站怎么宣传网站群建设管理规定
  • asp网站免费源码北京国贸网站建设
  • 阿里云官方网站 icp代备案管理系统厦门网站建设公司电话
  • seo撰写网站标题以及描述的案例百度seo优
  • 如何搭建购物网站在线课程网站建设规范
  • 深圳石岩做网站手机购物网站 设计
  • 网站不用备案品牌seo培训
  • 昆明网站建设公司猫咪科技农业产品如何建网站
  • 网站建设组成部分深圳推广服务
  • 网站提交了被收录后改怎么做服装网站建设策划书
  • 哪个网站可以做1040电脑网站建设在哪里
  • 网站一个页面多少钱山东省住房和建设网站
  • 东莞网站关键词优化网页翻译成中文后怎么还原
  • 联通网站服务器wordpress嵌入网页
  • 宜兴做网站wordpress不能编辑不能新建
  • 河南网站推广那家好wordpress 去除评论
  • 注册域名后怎么建站南宁网站建设哪家公司实