链队列

在这里插入图片描述
在这里插入图片描述

 interface IQueue<T>
    {
        int GetLength();
        void Clear();
        void EnQueue(T elem);
        void Dequeue();
      
        T Peek();
        bool IsEmepty();
/// <summary>
    /// 链队列
    /// </summary>
    /// <typeparam name="T"></typeparam>
    class LinkQueue<T> : IQueue<T>
    {
        private int count;   //元素个数
        private Node<T> front;//头指针
        private Node<T> rear;//尾指针

在这里插入代码片

        public LinkQueue()
        {
            count = 0;
            front = rear = new Node<T>(); //初始化指向头结点
        }
    


        public void Clear()
        {
            count = 0;
            front.Next = null;
            rear = null;
        }
    

在这里插入代码片

        //对头出队
        public T Dequeue()
        {
            //判断是否为空队
            //对头指针改变
            //count--
            if (rear==front)
            {
                throw new Exception("空队无法删除");
            }

            Node<T> p = front.Next;
            front.Next = p.Next;
            count--;
            return p.Data;

        }

在这里插入代码片

        //队尾入队
        public void EnQueue(T elem)
        {
            
            Node<T> newNode=new Node<T>(elem);
            //把新的节点添加到队尾
            //改变尾指针的指向地址
            //count++
            rear.Next = newNode;
            rear = newNode;
            count++;

        }


        public int GetLength()
        {
            return count;
        }

在这里插入代码片

        public bool IsEmepty()
        {
            return front == rear;
        }

在这里插入代码片

        public T Peek()
        {
            Node<T> p = front.Next;
            return p.Data;
        }

        void IQueue<T>.Dequeue()
        {
            
        }
    }
  class Program
    {
        static void Main(string[] args)
        {
            //Queue<int> sum=new Queue<int>(6);
            LinkQueue<int> sum=new LinkQueue<int>();
            Console.WriteLine(sum.IsEmepty());
            Console.WriteLine(sum.GetLength());
            sum.EnQueue(100);
            sum.EnQueue(200);
            sum.EnQueue(300);  
            sum.EnQueue(400);
            Console.WriteLine(sum.Dequeue());
            Console.WriteLine(sum.Peek());
            Console.WriteLine(sum.IsEmepty());
            sum.Clear();
            Console.WriteLine(sum.GetLength());
           
            Console.ReadKey();
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值