zoukankan      html  css  js  c++  java
  • 数据结构之顺序栈(一)

    顺序栈

    • 1.顺序栈是线性结构;
    • 2.满足先进后出的特点。

    示例:

    
    #include <iostream>
    #include <stdio.h>
    
    using namespace std;
    
    #define STACK_INT_SIZE 10 //存储空间初始分配量
    #define STACK_INTCREMENT 2 //存储空间分配增量
    
    typedef int SElemType;
    
    struct SqStack{
    	SElemType *base; //在构造之前和销毁后,base的值为NULL
    	SElemType *top;  //栈顶指针
    	int stacksize;   //当前已分配的存储空间,以元素为单位
    }; //顺序栈
    
    //顺序栈的基本操作
    void InitStack(SqStack &S)
    {
    	//构造一个空栈
    	if(!(S.base=(SElemType*)malloc(STACK_INT_SIZE*sizeof(SElemType)))){
    		return ;
    	}
    	
    	S.top=S.base;
    	S.stacksize=STACK_INT_SIZE;
    }
    
    
    void DestoryStack(SqStack &S)
    {
    	//销毁S
    	free(S.base);
    	S.base=NULL;
    	S.top=NULL;
    	S.stacksize=0;
    }
    
    void ClearStack(SqStack &S)
    {
    	//把S置为空栈
    	S.top=S.base;
    }
    
    int StackEmpty(SqStack S)
    {
    	if(S.top==S.base)
    	{
    		return 1;
    	}else{
    		return 0;
    	}
    }
    
    int StackLength(SqStack S)
    {
    	//返回S的元素个数,栈的长度
    	return S.top-S.base;
    }
    
    
    int GetTop(SqStack S,SElemType &e)
    {
    	//如果栈不空,则用e返回S的栈顶元素,返回值为1
    	//否则返回值为0
    	if(S.top>S.base)
    	{
    		e=*(S.top-1);
    		return 1;
    	}else{
    		return 0;
    	}
    		
    }
    
    
    void Push(SqStack &S,SElemType e)
    {
    	//插入元素e为新的栈顶元素
    	if(S.top-S.base>=S.stacksize) //栈满,分配空间
    	{
    		S.base=(SElemType *)realloc(S.base,(S.stacksize+STACK_INTCREMENT)*sizeof(SElemType));	
    		if(!S.base)
    			return;
    		S.top=S.base+S.stacksize;
    		S.stacksize+=STACK_INTCREMENT;
    	}
    	*(S.top)++=e;
    }
    
    int Pop(SqStack &S,SElemType &e)
    {
    	//若栈不空,删除栈S的栈顶元素,用e返回,返回值1
    	//若栈空,返回0
    	if(S.top==S.base)
    		return 0;
    	e=*--S.top;
    	return 1;
    }
    
    void StackTraverse(SqStack S,void(*visit)(SElemType))
    {
    	//从栈底到栈顶依次对栈中的每个元素调用visit()
    	while(S.top>S.base)
    	{
    		visit(*S.base++);
    	}
    	printf("
    ");
    }
    
    void print(SElemType e)
    {
    	printf("%d
    ",e);
    }
    
    
    int main(void)
    {
    	SqStack s;
    	SElemType e;
    	InitStack(s);
    	for(int j=1;j<=12;j++)
    	{
    		Push(s,j);
    	}
    	
    	cout<<"These elements are "<<endl;
    	StackTraverse(s,print);
    	
    	Pop(s,e);
    	printf("element on the top e=%d
    ",e);
    	printf("empty:%d(1:yes 0:no)
    ",StackEmpty(s));
    	GetTop(s,e);
    	printf("element on the top e=%d the length of stack %d
    ",e,StackLength(s));
    	
    	ClearStack(s);
    	printf("clear stack,empty?:%d(1:yes 0:no)
    ",StackEmpty(s));
    	
    	 DestoryStack(s);
    	printf("destory stack,s.top=%u s.base=%u s.stacksize=%d
    ",s.top,s.base, s.stacksize);
    	
    	system("pause");
    	return 0;
    }
    
    
  • 相关阅读:
    iframe与动作连处理
    selenium其他自动化操作
    使用seleniun模拟登陆qq空间
    selenium基本使用
    验证码识别 云打码之古诗文网验证识别
    图片爬取基础
    centos8下LAMP搭建Nextcloud
    浅谈centos8与centos7
    DHCP服务器配置及测试
    使用Apache服务器实现Nginx反向代理
  • 原文地址:https://www.cnblogs.com/xuelanga000/p/13563851.html
Copyright © 2011-2022 走看看