C++实现链栈相关操作代码
#include<iostream>
#include<cstdlib>
using namespace std;
#define MAXSIZE 100
#define OK 1
#define ERROR 0
typedef int Status;
typedef int Elemtype;
typedef struct StackNode
{
Elemtype data;
struct StackNode* next;
}StackNode, * Linklist;
Status InitStack(Linklist& S);//初始化链栈
Status CreateStack(Linklist& S, int len);//创建链栈
Status PushStack(Linklist& S, Elemtype e);//入链栈
Status PopStack(Linklist& S, Elemtype& e);//出链栈
Status GetStack(Linklist S);//取出链栈的栈顶元素
Status LenStack(Linklist S);//求取链栈的长度
Status PrintStack_1(Linklist S);//逆序打印链栈
Status PrintStack_2(Linklist S);//正序打印链栈
int main(void)
{
Linklist S;
S = NULL;
int e;
int k;
int len;
do {
cout << "\n*****链栈相关操作*****";
cout << "\n1.初始化一个空链栈";
cout << "\n2.随机创建一个包含正整数值的链栈";
cout << "\n3.将一个数e插入到链栈栈顶";
cout << "\n4.将链栈栈顶元素弹出,并输出元素的值";
cout << "\n5.获取链栈栈顶元素";
cout << "\n6.求链栈的长度";
cout << "\n7.输出链栈从栈顶到栈底的元素";
cout << "\n8.输出链栈从栈底到栈顶的元素";
cout << "\n0.结束相关操作";
cout << "\n输入想要进行相关操作的序号:";
cin >> k;
switch (k)
{
case 1:
{
if (InitStack(S))
cout << "初始化成功。\n" << endl;
else
cout << "初始化失败。\n" << endl;
break;
}
case 2:
{
cout << "输入想要创建链栈的长度:";
cin >> len;
if (CreateStack(S,len))
{
cout << "创建成功。\n";
}
else
{
cout << "创建失败。\n";
}
break;
}
case 3:
{
cout << "输入想要插入元素的数值x为:";
cin >> e;
if (PushStack(S, e)) cout << "插入成功。\n";
else cout << "插入失败。\n";
break;
}
case 4:
{
if (PopStack(S,e)) cout << "删除成功。\n";
else cout << "删除失败。\n";
break;
}
case 5:
{
if (GetStack(S)) cout << "输出成功。\n";
else cout << "输出失败。\n";
break;
}
case 6:
{
if (LenStack(S)) cout << "长度获取成功。\n";
else cout << "长度获取失败。\n";
break;
}
case 7:
{
if (PrintStack_1(S)) cout << "全部输出成功。\n";
else cout << "全部输出失败。\n";
break;
}
case 8:
{
if (PrintStack_2(S)) cout << "全部输出成功。\n";
else cout << "全部输出失败。\n";
break;
}
}
} while (k != 0);
return OK;
}
Status InitStack(Linklist& S)//初始化链栈
{
S = NULL;
return OK;
}
Status CreateStack(Linklist& S, int len)//创建链栈
{
StackNode* p;
int e;
cout << "\n输入想要创建链栈的数据:";
for (int i = 0; i < len; i++)
{
p = new StackNode;
cin >> e;
p->data = e;
p->next = S;
S = p;
}
return OK;
}
Status PushStack(Linklist& S, Elemtype e)//入链栈
{
StackNode* p;
p = new StackNode;
p->data = e;
p->next = S;
S = p;
return OK;
}
Status PopStack(Linklist& S, Elemtype& e)//出链栈
{
if (S == NULL) return ERROR;
StackNode* p;
p = new StackNode;
e = S->data;
p = S;
S = S->next;
delete p;
cout << "出链栈的元素为:" << e << endl;
return OK;
}
Status GetStack(Linklist S)//取出链栈的栈顶元素
{
if (S->next == NULL) return ERROR;
cout << "取出链栈的栈顶元素为:" << S->data << endl;
return OK;
}
Status LenStack(Linklist S)
{
StackNode* p;
p = new StackNode;
p = S;
int len = 0;
while (p)
{
p = p->next;
len++;
}
cout << "链栈的长度为:" << len << endl;
return OK;
}
Status PrintStack_1(Linklist S)//打印链栈
{
if (S == NULL)
{
cout << "链栈为空。" << endl;
}
cout << "链栈中的元素有:";
StackNode* p;
p = S;
while (p!=NULL)
{
cout << p->data << " ";
p = p->next;
}
return OK;
}
Status PrintStack_2(Linklist S)//递归实现正序打印链栈
{
if (S == NULL)
{
cout << "链栈为空。" << endl;
return ERROR;
}
if (S->next == NULL)
{
cout << "链栈中的元素有:";
cout << S->data << " ";
return OK;
}
PrintStack_2(S->next);
cout << S->data << " ";
}
C++实现链栈相关操作代码的更多相关文章
- java虚拟机栈 相关操作
针对JVM虚拟栈 和栈帧的操作 虚拟机栈: 栈元素是栈帧.方法调用,栈帧入栈,反之出栈. 栈帧:一个方法的运行空间. 1.局部变量表:方法定义的局部变量.方法的参数存在该表. 实例方法中有个隐含参数“ ...
- java 发送邮件 email相关操作代码测试,生成复杂格式邮件,发送邮件相关操作
项目源码下载:http://download.csdn.net/detail/liangrui1988/6720047 效果图: 相关代码: test1 package com.mail; impor ...
- 数据结构 - 链栈的实行(C语言)
数据结构-链栈的实现 1 链栈的定义 现在来看看栈的链式存储结构,简称为链栈. 想想看栈只是栈顶来做插入和删除操作,栈顶放在链表的头部还是尾部呢?由于单链表有头指针,而栈顶指针也是必须的,那干吗不让它 ...
- 利用JAVA API远程进行HDFS的相关操作
学习HDFS有一段时间了,现在把自己总结的HDFS的相关操作代码展示给大家. 主要有HDFS的增删改查,文件的追加,windows本地文件的上传,hdfs文件的下载,文件重命名,创建目录,文件是否存在 ...
- C语言实现链栈的初始化&进栈&出栈&读取栈顶元素
/*链表实现栈的一系列操作*/ #include<stdio.h> #include<stdlib.h> #define OK 1 #define ERROR 0 typede ...
- c/c++ 链栈
c/c++ 链栈 链栈 下面的代码实现了以下功能 函数 功能描述 push 压入 pop 弹出 show_list 打印 clear 释放所有内存空间 destroy 释放所有内存空间 nodesta ...
- HDFS文件目录操作代码
分布式文件系统HDFS中对文件/目录的相关操作代码,整理了一下,大概包括以下部分: 文件夹的新建.删除.重命名 文件夹中子文件和目录的统计 文件的新建及显示文件内容 文件在local和remote间的 ...
- java文件夹相关操作 演示样例代码
java文件夹相关操作 演示样例代码 package org.rui.io; import java.io.File; import java.io.FilenameFilter; import ja ...
- 42 github 开源代码 ——README.md语法/相关操作等
0 引言 最近在github上开源了pro/E二次开发的代码,发现README.md的编辑方式很有趣,需要稍微了解一下. 1 markdown语法 参考了两篇博客的内容,链接如下. https://b ...
- linux下进程相关操作
一.定义和理解 狭义定义:进程是正在运行的程序的实例. 广义定义:进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动. 进程的概念主要有两点: 第一,进程是一个实体.每一个进程都有它自己的 ...
随机推荐
- Potree 003 基于Potree Desktop创建自定义工程
1.第三方js库 第三方库js库选择dojo,其官网地址为https://dojotoolkit.org/,git地址为https://github.com/dojo/dojo,demo地址为http ...
- 真正“搞”懂HTTP协议08之重定向
我们知道,用来传输页面的协议就是HTTP协议,全称是超文本传输协议,而浏览器展示的页面则是用HTML编写的,HTML的全称则是超文本标记语言.你看,都叫做超文本,我在第一篇文章的时候也详细的聊过,超文 ...
- 探讨下如何更好的使用缓存 —— Redis缓存的特殊用法以及与本地缓存一起构建多级缓存的实现
大家好,又见面了. 本文是笔者作为掘金技术社区签约作者的身份输出的缓存专栏系列内容,将会通过系列专题,讲清楚缓存的方方面面.如果感兴趣,欢迎关注以获取后续更新. 通过前面的文章,我们一起剖析了Guav ...
- liunx系统安装JDK环境详细步骤
Liunx系统安装JDK环境详细步骤 一 下载liunx版本jdk压缩包 进入JDK官方网站下载jdk压缩包.下载前需要登入账户,可以自己注册一个账户! 也可以使用本博主提供的网盘下载https:// ...
- Java:枚举类型
Java:枚举类型 每博一文案 师父说:人活一世,每个人都有他的特别,每个人都值得被温柔相待.红尘一遭,每段经历都有它的必然, 每段经历都造就了现在的你,最快乐的事情,就是做自己,最浪漫的事情,就是爱 ...
- 定时调度插件------Sundial
1 插件概述 开源链接:https://gitee.com/dotnetchina/Sundial 作者:百小僧 版本:2.5.6 2 使用方式 2.1 安装 nuget :搜索Sundial或使用命 ...
- 【MRTK】HoloLens开发基础项目设置
前言 好记性不如烂笔头,之前做项目的时候很熟练很顺手就没有写笔记.因为排期问题项目中断几个月之后需要重新拾起来,结果发现自己现在忘记得差不多了,于是还是决定写点东西记录一下.即便是简单的项目设置,忘记 ...
- 11月29日内容总结——SQL注入问题、视图、触发器、事务、存储过程、函数、流程控制、索引、慢查询、数据库三大范式
目录 一.SQL注入问题 SQL注入问题引入 SQL注入概念和解决方案 二.视图 三.触发器 定义 代码 1.触发器命名有一定的规律 2.临时修改SQL语句的结束符 四.事务 事务的四大特性(ACID ...
- 运行第一个Go文件
Go学习(1)一. 使用GoLand运行第一个Go文件 目录 Go学习(1)一. 使用GoLand运行第一个Go文件 前言 一.创建项目 二.编辑运行/调试配置 三.编写并运行代码 总结 前言 Go语 ...
- rt-thread模糊到清晰系列: thread切换相关
// 创建thread tid = rt_thread_create("main", main_thread_entry, RT_NULL, RT_MAIN_THREAD_STAC ...