数据结构笔记4 栈

本文介绍了栈的基本概念及特点,详细解释了栈作为一种特殊的线性表,遵循后进先出(LIFO)原则的工作原理。同时,提供了使用C#语言实现栈的具体代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

栈的定义和概念

栈(Stack)是限制仅在表的一端进行插入和删除运算的线性表。
  (
1)通常称插入、删除的这一端为栈顶(Top),另一端称为栈底(Bottom)。
  (
2)当表中没有元素时称为空栈。
  (
3)栈为后进先出(Last In First Out)的线性表,简称为LIFO表。
     栈的修改是按后进先出的原则进行。每次删除(退栈)的总是当前栈中
"最新"的元素,即最后插入(进栈)的元素,而最先插入的是被放在栈的底部,要到最后才能删除。
 

栈在C#中的代码实现

using System;

namespace EveryDayStudy.数据结构
{
    
public class DAPStack
    {
        
private object[] _array;
        
private const int _defaultCapacity = 10;
        
private int _size;

        
public DAPStack()
        {
            _array 
= new object[_defaultCapacity];
            _size 
= 0;
        }

        
public DAPStack(int initialCapacity)
        {
            
if (initialCapacity <0)
            {
                
throw new ArgumentOutOfRangeException("栈空间不能小于零");
            }
            
if (initialCapacity <_defaultCapacity)
            {
                initialCapacity 
= _defaultCapacity;
            }

            _array 
= new object[initialCapacity];
            _size 
= 0;
        }

        
public virtual  object Pop()
        {
            
if (_size ==0)
            {
                
throw  new InvalidOperationException("栈内已经没有数据了。");
            }
            
object obj2 = _array[--this._size];
            _array[_size] 
= null;
            
return obj2;
        }

        
public virtual void Push(object obj)
        {
            
if (_size == _array.Length)
            {
                
object[] destinationArray  = new object[2*_array.Length];
                _array 
= destinationArray;
            }
            _array[_size
++= obj;
        }

        
public  virtual int Count
        {
            
get
            {
                
return _size;
            }
        }

    }
}

  其他

其他的好像没有什么好主意的了,大概是因为栈这个结构在我们上学的时候接触的太多了,还是这个栈本来就好理解吧。

其他的就不说了,这么晚了用本本蹭别人家的无线用写的。呵呵,有问题再改吧,等会睡觉的,明儿还上班的呢
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值