数据结构-线性表 2.顺序表实现(php)

1、顺序表代码实现如下,若有疑问,欢迎留言

class OrderList
{
    /**
     * @var 数据
     */
    private $data = [];
    /**
     * @var 下标
     */
    private $size = 0;

    /**
     * Function:add
     * 增加数据
     *  1、数组的值从后向前,都往后挪一个位置
     *  2、挪到index时用e替换里面的内容即可
     * @param $index
     * @param $e
     *
     * @return void
     */
    public function add($index, $e)
    {
        if ($index >= 0 && $index <= $this->size) {
            for ($i = $this->size -1;$i>=$index; --$i){
                $this->data[$i+1] = $this->data[$i];
            }
            $this->data[$index] = $e;
            $this->size++;
        } else {
            echo "AddLast failed. index<0 || index>size ";
        }
    }

    /**
     * Function:addFirst
     * 头部插入
     *
     * @param $e
     *
     * @return void
     */
    public function addFirst($e){
        $this->add(0,$e);
    }

    /**
     * Function:addLast
     * 尾部插入
     *
     * @param $e
     *
     * @return void
     */
    public function addLast($e){
        $this->add($this->size,$e);
    }

    /**
     * Function:remmove
     * 移除
     *
     * 1、将数组从传入索引的下一个索引,统统往前移动一个位置
     *
     * @param $index
     *
     * @return mixed
     */
    public function remove($index)
    {

//        if($this->size == count($this->data))
//        {
//            die("AddLast failed. Array is full");
//        }
        if($index<0 || $index>$this->size)
        {
            die("AddLast failed. index<0 || index>size");
        }

        $res = $this->data[$index];
        for( $i = $index; $i <= $this->size; ++$i) {
            $this->data[$i] = $this->data[$i+1];
        }
        $this->size--;
        return $res;

    }

    /**
     * Function:remowFirst
     * 移除第一个元素
     *
     * @return mixed
     */
    public function removeFirst()
    {
        return $this->remove(0);
    }

    /**
     * Function:removeLast
     * 移除最后一个元素
     *
     * @return mixed
     */
    public function removeLast()
    {
        return $this->remove($this->size - 1);
    }

    /**
     * Function:remowElement
     * 移动除掉某一个元素
     *
     * @param $e
     *
     * @return void
     */
    public function removeElement($e)
    {
        $index = $this->find($e);
        if($index != -1)
        {
            $this->remove($index);
        }
    }
    /**
     * Function:isEmpty
     * 是否为空
     *
     * @return bool
     */
    public function isEmpty()
    {
        return $this->size == 0;
    }

    /**
     * Function:get
     * 通过index获取数据
     *
     * @param $index
     *
     * @return mixed
     */
    public function get($index){
        if ($index >= 0 && $index < $this->size) {
            return $this->data[$index];
        } else {
            die("AddLast failed. index is illagal ");
        }
    }

    /**
     * Function:contains
     * 是否包含某一个元素,如果包含返回key
     *
     * @param $e
     *
     * @return bool
     */
    public function contains($e){
       for ($i = 0 ;$i < $this->size;$i++){
           if($this->data[$i] == $e)
           {
               return true;
           }
       }
       return false;
    }

    /**
     * Function:find
     * 查看某个元素是否包含在线性表中,如果存在,返回index
     *
     * @param $e
     *
     * @return int
     */
    public function find($e){
        for ($i = 0 ;$i < $this->size;$i++){
            if($this->data[$i] == $e)
            {
                return $i;
            }
        }
        return -1;
    }

    /**
     * Function:getData
     * 获取数据
     *
     *
     * @return 数据
     */
    public function getData()
    {
        return $this->data;
    }

    /**
     * Function:getSize
     * 获取线性表的指针
     *
     *
     * @return 下标
     */
    public function getSize()
    {
        return $this->size;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值