数据结构顺序栈和链栈的区别_数据结构链栈的实现代码

数据结构顺序栈和链栈的区别_数据结构链栈的实现代码实现顺序栈和链栈的、栈的初始化、入栈、出栈、获取栈顶元素功等功能。顺序栈代码如下:#include “pch.h”#include <iostream>#include<Windows.h>#include<string>using namespace std;#define OK 1#define ERROR 0#define OVE…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

实现顺序栈和链栈的、栈的初始化、入栈、出栈、获取栈顶元素功等功能。

顺序栈

代码如下:

#include "pch.h"
#include <iostream>
#include<Windows.h>
#include<string>

using namespace std;

#define OK 1
#define ERROR 0
#define OVER -2
#define MAXSIZE 100

typedef int Status;		//返回状态

//顺序表结构体
struct SqStack
{ 
   
	char *base;
	char *top;
	int StackSize;
};

//初始化顺序栈
Status InitStack(SqStack &S)
{ 
   
	S.base = new char[MAXSIZE];
	if (!S.base)
	{ 
   
		Sleep(3000);
		exit(OVER);
	}
	S.top = S.base;
	S.StackSize = MAXSIZE;
	return OK;
}

//入栈
Status Push(SqStack &s, char &e)
{ 
   
	if (s.top - s.base == s.StackSize)
	{ 
   
		return ERROR;
	}

	*(s.top) = e;			//元素入栈,栈顶指针+1
	s.top++;
	return OK;
}

//出栈
Status Pop(SqStack &s, char &e)
{ 
   
	if (s.base == s.top)
	{ 
   
		return ERROR;
	}
	e = *(s.top - 1);		//这是出栈元素
	s.top--;
	return OK;
}
//得到栈顶元素
char GetTop(SqStack &s)
{ 
   
	if (s.top != s.base)
	{ 
   
		return *(s.top - 1);
	}
}
//打印栈元素
void PrintStack(SqStack &s)
{ 
   
	if (s.top != s.base)
	{ 
   
		cout << "栈的元素为:";
		int k = 0;
		for (int i = (s.top - s.base); i > 0; i--)
		{ 
   

			cout << *(s.top - 1) << " ";
			--s.top;
			k++;
		}
		for (int j = 0; j <k; j++)
		{ 
   
			++s.top;
		}
	}
}

int main()
{ 
   
	SqStack s;

	InitStack(s);
	int n;
	cout << "请输入初始个数:";
	cin >> n;
	cout << "请输入元素:" << endl;
	for (int i = 0; i < n; i++)
	{ 
   
		char p;
		cin >> p;
		Push(s, p);
	}
	PrintStack(s);
	cout << "栈顶为:" << GetTop(s) << endl;
	char p1;
	Pop(s, p1);
	cout << "出栈后";
	PrintStack(s);
	return 0;
}

结果如下:
在这里插入图片描述

链栈

代码如下:

#include "pch.h"
#include <iostream>
#include<string>
#include<Windows.h>
using namespace std;

#define OK 1
#define ERROR 0
#define OVER -2
#define MAXSIZE 100

typedef int Status;		//返回状态


typedef struct StackNode
{ 
   
	char date;
	StackNode *next;
}*LinkStack;

//初始化链栈
Status InitStack(LinkStack s)
{ 
   
	s = NULL;
	return OK;
}

//入栈
Status Push(LinkStack s, char e)
{ 
   
	LinkStack p;
	p = new StackNode;
	p->date = e;
	p->next = s;
	s = p;
	return OK;
}

//出栈
Status Pop(LinkStack s, char &e)
{ 
   
	LinkStack p;
	if (s == NULL)
	{ 
   
		return ERROR;
	}
	e = s->date;
	p = s;				//用p临时保存栈顶元素的值
	s = s->next;		//修改栈顶指针
	delete p;
	return OK;
}

//取栈顶元素的值
char Getchar(LinkStack s)
{ 
   
	if (s!=NULL)
	{ 
   
		return s->date;
	}
	cout << "栈为空,无法取栈顶元素!" << endl;
	return ERROR;
}

int main()
{ 
   
	StackNode s;
	InitStack(&s);
	char a, b, c;
	a = 'c', b = 'b', c = 'a';
	Push(&s, a);
	Push(&s, b);
	Push(&s, c);
	cout << "出栈前栈顶为:";
	Getchar(&s);
	char e;
	Pop(&s,e);
	cout << "出栈后栈顶为:";

	return 0;
}

结果如下:
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170978.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux内核编程_linux内核是什么

    linux内核编程_linux内核是什么什么是操作系统?指在系统中负责完成最基本功能和系统管理的部分,操作系统有哪些组成部分?内核——操作系统的内在核心 设备驱动程序 启动引导程序 命令行shell 其他种类的用户界面—-操作系统的外在表象 基本的文件管理工具和系统工具Linux内核的组成Linux内核源代码目录结构是什么,各目录有什么含义?arch:包含和硬件体系结构相关的代码,每种平台占一…

    2022年10月8日
    4
  • 列车调度 思路解析

    列车调度 思路解析火车站的列车调度铁轨的结构如下图所示。两端分别是一条入口(Entrance)轨道和一条出口(Exit)轨道,它们之间有N条平行的轨道。每趟列车从入口可以选择任意一条轨道进入,最后从出口离开。在图中有9趟列车,在入口处按照{8,4,2,5,3,9,1,6,7}的顺序排队等待进入。如果要求它们必须按序号递减的顺序从出口离开,则至少需要多少条平行铁轨用于调度?输入格式:输入第一行给出一个…

    2022年7月26日
    5
  • 设备管理器里“SM总线控制器”、“其它PCI桥设备”驱动有问题[通俗易懂]

    设备管理器里“SM总线控制器”、“其它PCI桥设备”驱动有问题[通俗易懂]WinXP重装系统后设备管理器里面出现黄色问号。各自是“SM总线控制器”和“其它PCI桥设备“,主板是七彩虹的,芯片组是geForce7025的,南桥是nForce630a,用七彩虹官网的主板驱动装了没用。用驱动人生先备份还有一个相同主板的机器的驱动。得到 NVIDIAnForcePCISystemManagement_*.zip, NVIDIANetworkBus…

    2022年5月3日
    78
  • 数据库:实体关系图(ER图)「建议收藏」

    数据库:实体关系图(ER图)「建议收藏」1,组成元素元素 描述 表示形似 实体 客观存在并可以相互区别的事物 用矩形框,矩形框内写明实体名 属性 实体所具有的一个属性 用椭圆型表示,并用无向边将其与相应的实体连接起来 关系 实体和实体之间以及实体内部的关系 用菱形表示,菱形框内写明联系名,并用无向边分别与有关实体连接起来, 同时在无向边旁边标上联系的类型 2,关系详解一,一对一一对一关系是指对于实体集A与实体集B,A中的每一个实体至多与B中

    2022年6月21日
    97
  • Spring Cloud原理详解[通俗易懂]

    Spring Cloud原理详解[通俗易懂]概述毫无疑问,SpringCloud是目前微服务架构领域的翘楚,无数的书籍博客都在讲解这个技术。不过大多数讲解还停留在对SpringCloud功能使用的层面,其底层的很多原理,很多人可能并不知晓。因此本文将通过大量的手绘图,给大家谈谈SpringCloud微服务架构的底层原理。实际上,SpringCloud是一个全家桶式的技术栈,包含了很多组件。本文先从其最核心的几个组件入手,来剖…

    2022年6月7日
    75
  • 如何通过maven打包可执行jar包[通俗易懂]

    如何通过maven打包可执行jar包[通俗易懂]一、目的将代码打包成jar包有四种形式:1、只打包本项目的代码,不包括依赖的jar包,并且不可直接通过java-jarxxx.jar执行(应用场景:我们日常使用依赖的jar包)2、只打包本项目的代码,不包括依赖的jar包,并且可以直接通过java-jarxxx.jar执行(应用场景:执行时依赖的jar包存在在本jar包外部,减少jar体积)3、打包本项目的代码,同时将依赖的jar包解压后的文件复制到本jar包中,可以直接通过java-jarxxx.jar执行(应用场景:直接执行,

    2022年10月4日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号