2013-08-30 20:58 1876人阅读 评论(0) 收藏 举报

链栈是借用单链表实现的栈。其不同于顺序栈之处在于:

1、链栈的空间是程序运行期间根据需要动态分配的,机器内存是它的上限。而顺序栈则是

静态分配内存的。

2、链栈动态分配内存的特性使得它一般无需考虑栈溢出的问题。

链栈的的组织结构如下图所示。容易发现其是架构的单链表的基础之上的。

下面介绍下我用C++实现的链栈,VC6下调试。

1、文件的组织结构

2、ls.h链栈类的说明

  1. #ifndef _LS_H_
  2. #define _LS_H_
  3. typedef int dataType;
  4. struct node                   //链栈节点
  5. {
  6. dataType data;            //数据域
  7. node *next;               //指针域
  8. };
  9. class ls
  10. {
  11. public:
  12. ls();
  13. ~ls();
  14. void push(dataType var); //压栈
  15. void pop();              //出栈.出栈之前并不判断栈是否已空.需要通过isEmpty()判断
  16. dataType stackTop();     //取栈顶元素,栈顶无变化.不提前判断栈是否为空
  17. bool isEmpty();          //判空.空返回true,反之返回false
  18. //bool isFull();         //判满.链栈是动态分配内存空间的,无需判满
  19. private:
  20. node *top;               //栈顶指针.top=NULL表示为空栈
  21. };
  22. #endif

3、ls.cpp链栈类成员函数的定义

  1. #include <iostream>
  2. #include "ls.h"
  3. using namespace std;
  4. ls::ls()
  5. {
  6. top = NULL;            //top=NULL表示链栈为空
  7. }
  8. ls::~ls()
  9. {
  10. node *ptr = NULL;
  11. while(top != NULL)     //循环释放栈节点空间
  12. {
  13. ptr = top->next;
  14. delete top;
  15. top = ptr;
  16. }
  17. }
  18. void ls::push(dataType var)
  19. {
  20. node *ptr = new node;
  21. ptr->data = var;        //新栈顶存值
  22. ptr->next = top;        //新栈顶指向旧栈顶
  23. top = ptr;              //top指向新栈顶
  24. }
  25. void ls::pop()
  26. {
  27. node *ptr = top->next;  //预存下一节点的指针
  28. delete top;             //释放栈顶空间
  29. top = ptr;              //栈顶变化
  30. }
  31. dataType ls::stackTop()
  32. {
  33. return top->data;       //返回栈顶元素,并不判断栈是否已空
  34. }
  35. bool ls::isEmpty()
  36. {
  37. return top == NULL;     //栈顶为NULL表示栈空
  38. }

4、main.cpp

  1. #include <iostream>
  2. #include "ls.h"
  3. using namespace std;
  4. int main()
  5. {
  6. ls exp;
  7. int i = 0;
  8. for(i=0;i<3;++i)
  9. {
  10. exp.push(i);
  11. }
  12. for(i=0;i<3;i++)
  13. {
  14. if(!exp.isEmpty())
  15. {
  16. cout<<exp.stackTop()<<endl;
  17. exp.pop();
  18. }
  19. }
  20. return 0;

链栈的c++实现的更多相关文章

  1. 03链栈_LinkStack--(栈与队列)

    #include "stdio.h" #include "stdlib.h" #include "io.h" #include " ...

  2. 从零开始学C++之数据封装与抽象:分别用C和C++来实现一个链栈

    下面通过分别用C和C++来实现一个链栈(链表实现),从中体会数据封装抽象的思想: C语言实现:  C++ Code  1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 ...

  3. java与数据结构(6)---java实现链栈

    栈之链式存储结构链栈 链栈 栈的链式存储结构成为链栈.链栈是没有头结点,头结点就是栈顶指针top. 代码结构 package list; public interface Stackable;公共接口 ...

  4. 链栈之C++实现

    链栈是借用单链表实现的栈.其不同于顺序栈之处在于: 1.链栈的空间是程序运行期间根据需要动态分配的,机器内存是它的上限.而顺序栈则是 静态分配内存的. 2.链栈动态分配内存的特性使得它一般无需考虑栈溢 ...

  5. C++实现链栈的基本操作

    之前对顺序栈写了基本操作,认为有必要也动手练练栈的链表实现. 对于链栈,一般不会出现栈满的情况. 链栈头文件定义例如以下: #ifndef CSTOCK_H_ #define CSTOCK_H_ ty ...

  6. 【小白成长撸】--链栈(C语言版)

    // 链栈.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <stdio.h> #include <st ...

  7. C语言简单实现链栈基本几个功能(适合新手看,大神可指正)

            接着上一次的顺序栈,今天我记一下链栈,因为我也是刚学不久,有些地方也稍稍理解不了,所以,一起共勉.我会用我自己结合教材上画的图,争取跟代码一起结合,用文字和图最大化的解释代码,这样的话 ...

  8. 数据结构——Java实现链栈

    一.分析 栈是限定仅在表的一端进行插入或删除操作的线性表,对于栈来说,操作端称为栈顶,另一端则称为栈底,栈的修改是按照后进先出的原则进行的,因此又称为后进先出的线性表. 链栈是指采用链式存储结构实现的 ...

  9. C语言实现链栈的初始化&进栈&出栈&读取栈顶元素

    /*链表实现栈的一系列操作*/ #include<stdio.h> #include<stdlib.h> #define OK 1 #define ERROR 0 typede ...

  10. C语言简单实现链栈基本几个功能

            接着上一次的顺序栈,今天我记一下链栈,因为我也是刚学不久,有些地方也稍稍理解不了,所以,一起共勉.我会用我自己结合教材上画的图,争取跟代码一起结合,用文字和图最大化的解释代码,这样的话 ...

随机推荐

  1. 将CSV文件中的数据导入到SQL Server 数据库中

    导入数据时,需要注意 CSV 文件中的数据是否包含逗号以及双引号,存在时,导入会失败 选择数据库 -> 右键 -> 任务 -> 导入数据 ,然后根据弹出的导入导出向导(如下图)中的提 ...

  2. JS实现“双色球”

    需求: 双色球玩法简单介绍: “双色球”彩票投注区分为红色球号码区和蓝色球号码区.每注投注号码由6个红色球号码和1个蓝色球号码组成.红色球号码从1--33中选择:蓝色球号码从1--16中选择.程序要求 ...

  3. Selenium2学习(十一)-- select下拉框

    本篇以百度设置下拉选项框为案例,详细介绍select下拉框相关的操作方法. 一.认识select    1.打开百度-设置-搜索设置界面,如下图所示 2.箭头所指位置,就是select选项框,打开页面 ...

  4. One Order行项目里Item Category是怎么计算出来的

    One Order的行项目里有个字段叫Item Category,我们在行项目里加入一个product后,就会自动带出Item Category来.这个值是怎么计算出来的? 检查CRMD_ORDERA ...

  5. mysql数据库 BETWEEN 语法的用法和边界值解析

    between用法: 用于where表达式中,选取两个值之间的数据,如: SELECT id FROM user WHERE id BETWEEN value1 AND value2; 当betwee ...

  6. 模线性方程&&中国剩余定理及拓展

    一.求解模线性方程 由ax=b(mod n) 可知ax = ny + b 就相当于ax + ny = b 由扩展欧几里得算法可知有解条件为gcd(a, n)整除d 可以直接套用扩展欧几里得算法 最终由 ...

  7. Android(java)学习笔记13:线程组的概述和使用

    1. Java中使用ThreadGroup来表示线程组,它可以对一批线程进行分类管理,Java允许程序直接对线程组进行控制. (1)默认情况下,所有的线程都属于主线程组. public final T ...

  8. Spark Streamming 基本输入流I(-) :File/Hdfs

    Spark Streamming 基本输入流I(-):从文件中进行读取 文件读取1:本地文件读取 这里我只给出实现代码及操作步骤 1.在本地目录下创建目录,这里我们创建目录为~/log/ 2.然后手动 ...

  9. [18/11/11] java标识符及变量

    一.标识符规范 1.必须以字母.下划线 .美元符号开头. 即数字不能作为开头,其它位随便 2.不可以是java关键字(即保留字),  如static .class.new 等 .    注:int 年 ...

  10. Linux 安装ngnix

    第一步:把nginx的源码包上传到linux系统/home 第二步:解压缩 [root@localhost ~]# tar zxf nginx-1.8.0.tar.gz 第三步:使用configure ...