using System.Collections;//引入命名空间 namespace _4 { class ArrayListTest { static void Main(string[] args) { ArrayList arrlist = new ArrayList();//实例化一个ArrayList对象 //使用Add方法向ArrayList中添加元素,将元素添加到ArrayList对象的末尾 arrlist.Add("苹果"); arrlist.Add("香蕉"); arrlist.Add("葡萄"); foreach (int n in new int[3] { 0, 1, 2 }) { arrlist.Add(n); } //移除值为的第一个元素 arrlist.Remove(0); //移除当前索引为的元素,即第个元素 arrlist.RemoveAt(3); //在指定索引处添加一个元素 arrlist.Insert(1, "apple"); //遍历ArrayList,并输出所有元素 for (int i = 0; i < arrlist.Count; i++) { Console.WriteLine(arrlist[i].ToString()); } } } }
2.Stack类
Stack(堆栈)类主要实现了一个LIFO(Last In First Out,后进先出)的机制。元素从栈的顶部插入(入栈操作),也从堆的顶部移除(出栈操作)。在Stack中主要使用Push,Pop,Peek三个方法对栈进行操作。Push方法用于将对象插入 Stack 的顶部;Pop方法用于移除并返回位于 Stack 顶部的对象;Peek方法用于返回位于 Stack 顶部的对象但不将其移除。
示例 Stack的使用
示例将介绍如何创建一个Stack,如何添加项、移除项以用如何遍历Stack。程序代码如下:
using System.Collections;//引入命名空间 namespace _5 { class StackTest { static void Main(string[] args) { //实例化Stack类的对象 Stack stack = new Stack(); //入栈,使用Pust方法向Stack对向中添加元素 for (int i = 1; i < 6;i++) { stack.Push(i); Console.WriteLine("{0}入栈",i); } //返回栈顶元素 Console.WriteLine ("当前栈顶元素为:{0}",stack.Peek().ToString ()); //出栈 Console.WriteLine("移除栈顶元素:{0}", stack.Pop().ToString()); //返回栈顶元素 Console.WriteLine("当前栈顶元素为:{0}", stack.Peek().ToString()); //遍历栈 Console.WriteLine("遍历栈"); foreach (int i in stack) { Console.WriteLine(i); } //清空栈 while(stack .Count!=0) { int s = (int)stack.Pop(); Console.WriteLine("{0}出栈",s); } } } }
3.Queue类
Queue(队列)类主要实现了一个FIFO(First In First Out,先进先出)的机制。元素在队列的尾部插入(入队操作),并从队列的头部移出(出队操作)。在Queue中主要使用Enqueue、Dequeue、Peek三个方法对队进行操作。Enqueue方法用于将对象添加到 Queue 的结尾处;Dequeue方法移除并返回位于 Queue 开始处的对象;Peek方法用于返回位于 Queue 开始处的对象但不将其移除。
示例 Queue的使用
示例将介绍如何创建一个Queue,如何添加项、移除项以用如何遍历Queue。程序代码如下:
using System.Collections;//引入命名空间 namespace _6 { class QueueTest { static void Main(string[] args) { //实例化Queue类的对象 Queue queue = new Queue(); //入栈,使用Pust方法向Stack对向中添加元素 for (int i = 1; i < 6; i++) { queue .Enqueue(i); Console.WriteLine("{0}入队", i); } //返回队开始处的元素 Console.WriteLine("当前队开始处元素为:{0}", queue.Peek().ToString()); //遍历队 Console.WriteLine("遍历队"); foreach (int i in queue) { Console.WriteLine(i); } //清空栈 while (queue.Count != 0) { int q = (int)queue.Dequeue (); Console.WriteLine("{0}出队", q); } } } }