栈的简单实现(C#)

栈是线性表的一个特例,因为栈只能对线性表的固定一端进行插入和删除操作,对其它位置不能进行操作,也就是“后进先出”的特性,下面为栈的简单实现代码:

using System;

namespace Review
{
	/// <summary>
	/// 栈的实现代码
	/// </summary>
	public class Stack
	{
		private object[] _array;//存放元素的数组
		private const int _defalutCapacity=10;//默认容量
		private int _size;//指示元素个数
		
		public int Count
		{
			get{return this._size;}
		}
		
		public Stack()
		{
			this._array=new object[_defalutCapacity];
			this._size=0;
		}
		
		public Stack(int initialCapacity)
		{
			if(initialCapacity<0)
			{
				throw new ArgumentOutOfRangeException("栈容量不能小于0");
			}
			if(initialCapacity<_defalutCapacity)
			{
				initialCapacity=_defalutCapacity;
			}
			this._array=new object[initialCapacity];
			this._size=0;
		}
		/// <summary>
		/// 出栈操作
		/// </summary>
		/// <returns></returns>
		public virtual object Pop()
		{
			if(this._size==0)
			{
				throw new InvalidOperationException("栈内已经没有数据");
			}
			object tmpObj=this._array[--this._size];//取栈顶元素
			this._array[this._size]=null;//删除栈顶元素
			return tmpObj;
		}
		/// <summary>
		/// 进栈操作
		/// </summary>
		/// <param name="obj"></param>
		public virtual void Push(object obj)
		{
			if(this._size==this._array.Length)
			{
				//如果空间已满,则使用新空间,并且空间容量为原来的两倍
				object [] destinationArray=new object[2*this._array.Length];
				Array.Copy(this._array,0,destinationArray,0,this._size);
				this._array=destinationArray;
			}
			this._array[this._size++]=obj;
		}
	}
}

转载于:https://www.cnblogs.com/wangqun/archive/2010/01/13/1646808.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值