• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

线性表C#实现

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

概念

  主要参考C#数据结构一书

  线性表顺序表

代码

线性表接口

using System;
using System.Collections.Generic;
using System.Text;

namespace CSharpDemo
{
    public interface ILinearList<T>
    {
        int GetLength();

        void Clear();

        bool IsEmpty();

        void Append(T item);

        void Insert(T item, int i);

        void Delete(int i);

        T GetElement(int i);

        int Locate(T item);
    }
}

 顺序表

using System;
using System.Collections.Generic;
using System.Text;

namespace CSharpDemo
{
    /// <summary>
    /// 顺序表实现
    /// </summary>
    /// <typeparam name="T"></typeparam>
    public class SequenceList<T>:ILinearList<T>
    {
        #region Field and Property
        
        private int maxsize;
        private T[] data;
        private int last;

        public int MaxSize
        {
            get
            {
                return this.maxsize;
            }
            set
            {
                this.maxsize = value;
            }
        }

        public int Last
        {
            get
            {
                return this.last;
            }
        }

        #endregion

        public T this[int i]
        {
            get
            {
                return data[i];
            }
            set
            {
                data[i] = value;
            }
        }

        public SequenceList(int size)
        {
            this.MaxSize = size;
            data = new T[size];
            last = -1;
        }

        #region ILinearList<T> Member

        public int GetLength()
        {
            return last + 1;
        }

        public void Clear()
        {
            last = -1;
        }

        public bool IsEmpty()
        {
            return last == -1 ? true : false;
        }

        public void Append(T item)
        {
            data[++last] = item;
        }

        public void Insert(T item, int index)
        {
            for (int i = last; i >= index; i--)
            {
                data[i + 1] = data[i];
            }

            data[index] = item;
            ++last;
        }

        public void Delete(int index)
        {
            for (int i = index; i <= last; i++)
            {
                data[i] = data[i + 1];
            }

            --last;
        }

        public T GetElement(int index)
        {
            if (IsEmpty())
            {
                return default(T);
            }

            return data[index];
        }

        public int Locate(T item)
        {
            int flag = -1;

            for (int i = 0; i <= last; i++)
            {
                if (item.Equals(data[i]))
                {
                    flag = i;
                    break;
                }
            }

            return flag;
        }

        #endregion

        public override string ToString()
        {
            string dataString = string.Empty;

            for (int i = 0; i <= last; i++)
            {
                dataString += data[i] + " ";
            }

            return dataString;
        }
    }
}

 

 

 

  

  


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C#引用类型和值类型的区别发布时间:2022-07-10
下一篇:
正经学C#_布尔运算[布尔值与其布尔运算符]:《c#入门经典》发布时间:2022-07-10
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap