• myvector.h

     #pragma once
    
     //自己写的vector模板库
    template <class T>
    class myvector
    {
    public:
    //构造
    myvector();
    //析构
    ~myvector();
    //尾插
    void push_back(T t);
    //索引
    T *find(T t);
    //改变
    void change(T*pos, T t);
    //删除
    void del(T t);
    //显示
    void show();
    //重载[]操作符
    T operator [](int i); //指定位置插入
    void insert(T findt, T t);
    public:
    //数据指针
    T *p;
    //标记内存长度
    int n;
    //实际长度
    int realn;
    };
  • myvector.cpp
     #include "myvector.h"
    
     //构造初始化
    template <class T>
    myvector<T>::myvector()
    {
    p = nullptr;
    n = realn = ;
    } //析构函数清空内存
    template <class T>
    myvector<T>::~myvector()
    {
    if (p!=nullptr)
    {
    delete []p;
    p = nullptr;//清空
    }
    } //尾部插入
    template <class T>
    void myvector<T>::push_back(T t)
    {
    //如果是空指针
    if (p==nullptr)
    {
    //分配内存
    p = new T;
    //赋值
    *p = t;
    //真实的长度和当前长度都赋值为1
    realn = n = ;
    }
    else
    {
    //如果不为空则重新分配内存
    T *ptemp = new T[n + ];
    //拷贝到新的空间
    for (int i = ; i < n;i++)
    {
    *(ptemp + i) = *(p + i);
    }
    //赋值最后一个元素
    *(ptemp + n) = t;
    //把原来的空间给删除
    delete []p; //指向新的空间
    p = ptemp; //真实长度与预留总长度都加1
    realn += ;
    n += ;
    }
    } //显示数据
    template <class T>
    void myvector<T>::show()
    {
    if (p==NULL)
    {
    return;
    }
    else
    {
    //遍历
    for (int i = ; i < realn;i++)
    {
    cout << p[i] << " ";
    }
    cout << "\n";
    }
    } //查询某一个数据
    template <class T>
    T * myvector<T>::find(T t)
    {
    //遍历查询,返回指针位置
    for (int i = ; i < realn; i++)
    {
    if (t==*(p+i))
    {
    return p + i;
    }
    }
    return nullptr;
    } //改变指定位置的数据
    template <class T>
    void myvector<T>::change(T*pos, T t)
    {
    //如果位置为空
    if (pos==nullptr)
    {
    return;
    }
    //如果不为空
    else
    {
    *pos = t;
    }
    } //删除某指定的第一个数据
    template <class T>
    void myvector<T>::del(T t)
    {
    //标识有没有找到
    int pos = -;
    //遍历查找,如果找到了记录位置
    for (int i = ; i < realn; i++)
    {
    if (t == *(p + i))
    {
    pos = i;
    break;
    }
    }
    //如果找到
    if (pos!=-)
    {
    //如果是最后一个元素
    if (pos== realn-)
    {
    realn -= ;
    }
    //如果不是最后一个元素,则向前移动
    else
    {
    for (int i = pos; i < realn-;i++)
    {
    p[i] = p[i + ];
    }
    realn -= ;
    }
    }
    } //插入
    template <class T>
    void myvector<T>::insert(T findt, T t)
    {
    //如果预留长度满了
    if (n == realn)
    {
    //找到指定位置
    int pos = -;
    for (int i = ; i < realn; i++)
    {
    if (findt == *(p + i))
    {
    pos = i;
    break;
    }
    }
    //如果找到了
    if (pos != -)
    {
    //重新分配内存并拷贝
    T *ptemp = new T[n + ];//重新分配内存
    for (int i = ; i < n; i++)
    {
    *(ptemp + i) = *(p + i);//拷贝
    }
    //删除原数据
    delete[] p;
    //指向新内存
    p = ptemp;
    //预留长度加1
    realn += ;
    //真实长度加1
    n += ; //指定位置数据往后移
    for (int i = realn - ; i >= pos; i--)
    {
    p[i + ] = p[i];//往前移动
    }
    //要插入的位置赋值
    p[pos] = t;
    }
    }
    //如果预留的长度没有满,则不用重新分配内存
    else
    {
    //找到指定位置
    int pos = -;
    for (int i = ; i < realn; i++)
    {
    if (findt == *(p + i))
    {
    pos = i;
    break;
    }
    }
    //如果找到了
    if (pos != -)
    {
    //指定位置数据往后移
    for (int i = realn - ; i >= pos; i--)
    {
    p[i + ] = p[i]; }
    p[pos] = t;
    realn += ;
    }
    }
    } //重载[]运算符
    template <class T>
    T myvector<T>::operator [](int i)
    {
    if (i < || i>=realn)
    {
    return NULL;
    }
    return p[i];
    }
  • main.cpp
     #include <iostream>
    #include<stdlib.h>
    #include <vector>
    #include <string>
    #include "myvector.h"
    #include "myvector.cpp"
    using namespace std; //测试函数
    void main()
    {
    myvector<int> myv1;
    myv1.push_back();
    myv1.push_back();
    myv1.push_back();
    myv1.push_back();
    myv1.push_back();
    myvector<int> myv2;
    myv2.push_back();
    myv2.push_back();
    myv2.push_back(); myvector<int> myv3;
    myv3.push_back();
    myv3.push_back();
    myv3.push_back();
    myv3.push_back(); myvector< myvector<int>* > myvv;//自己写的模板嵌套用指针 myvv.push_back(&myv1);
    myvv.push_back(&myv2);
    myvv.push_back(&myv3);
    myvv[]->show();
    myvv[]->show();
    myvv[]->show(); cout << myv1[] << endl;
    cin.get(); }

35.自己实现vector模板库myvector的更多相关文章

  1. c++转载系列 std::vector模板库用法介绍

    来源:http://blog.csdn.net/phoebin/article/details/3864590 介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作 ...

  2. 143.vector模板库

    myvector.h #pragma once #include <initializer_list> #include <iostream> using namespace ...

  3. C++ 标准模板库(STL)——容器(Containers)的用法及理解

    C++ 标准模板库(STL)中定义了通用的模板类和函数,这些模板类和函数可以实现多种流行和常用的算法和数据结构,如向量(vector).队列(queue).栈(stack).set.map等.这次主要 ...

  4. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

  5. C++STL模板库序列容器之vector

    目录 STL之Vecter 一丶STL简介 二丶Vector用法 1.vector容器的使用 2.vector迭代器. 3.vector中的方法. 三丶常用算法 1.常见算法中的算法方法. 2.sor ...

  6. C++标准模板库(STL)之Vector

    在C中,有很多东西需要自己实现.C++提供了标准模板库(Standard Template Libray,STL),其中封装了很多容器,不需要费力去实现它们的细节而直接调用函数来实现功能. 具体容器链 ...

  7. C++的标准模板库STL中实现的数据结构之顺序表vector的分析与使用

    摘要 本文主要借助对C++的标准模板库STL中实现的数据结构的学习和使用来加深对数据结构的理解.即联系数据结构的理论分析和详细的应用实现(STL),本文是系列总结的第一篇,主要针对线性表中的顺序表(动 ...

  8. C++:标准模板库vector

    一:介绍 vector是C++标准模板库,是一个容器,底层是数组,为连续内存. 命名空间为std,所属头文件为<vector>   注意:不是<vector.h> vector ...

  9. 标准模板库(STL)学习指南之sort排序

    对于程序员来说,数据结构是必修的一门课.从查找到排序,从链表到二叉树,几乎所有的算法和原理都需要理解,理解不了也要死记硬背下来.幸运的是这些理论都已经比较成熟,算法也基本固定下来,不需要你再去花费心思 ...

随机推荐

  1. Executors线程池关闭时间计算

    Executors线程池关闭时间计算 学习了:http://blog.csdn.net/wo541075754/article/details/51564359 https://www.cnblogs ...

  2. [Angular] Fetch non-JSON data by specifying HttpClient responseType in Angular

    By default the new Angular Http client (introduced in v4.3.1) uses JSON as the data format for commu ...

  3. 百度地图 key申请以及基础地图的演示

    之前做过一个拼车的项目,用到了百度地图,如今做电商项目,也遇到了要使用地图,可是刚来这公司不久项目不是自己做的,今天一个同事说定位那边有点问题,所以如今不忙,好好搞下地图,为了以后业务扩展或者出现故障 ...

  4. PC端 java 开发蓝牙所遇到的问题

    由于项目的原因.要在电脑上开发一个通过蓝牙传送数据的client.我採用的是JAVA,JSME开发. client:去搜素蓝牙信号,然后找到对应的蓝牙信号进行连接. 服务端:client须要进行连接的 ...

  5. PostgreSQL hstore 列性能提升一例

    PostgreSQL 支持hstore 来存放KEY->VALUE这类数据, 事实上也相似于ARRAY或者JSON类型.  要高效的使用这类数据,当然离不开高效的索引.我们今天就来看看两类不同的 ...

  6. D3D 线列 小样例

    画两条线 #pragma once #pragma comment(lib,"d3d9.lib") #pragma comment(lib,"d3dx9.lib" ...

  7. m_Orchestrate learning system---四、多看参考文档很多事情很轻松就解决了

    m_Orchestrate learning system---四.多看参考文档很多事情很轻松就解决了 一.总结 一句话总结:多看参考文档啊 1.面包屑导航如何实现? 1 <ol class=& ...

  8. Kali linux 2016.2(Rolling)中的payloads模块详解

    不多说,直接上干货! 前期博客 Kali linux 2016.2(Rolling)中的Exploits模块详解 payloads模块,也就是shellcode,就是在漏洞利用成功后所要做的事情.在M ...

  9. 关于AJAX异步请求的那些事儿(1)

    1.什么事AJAX? Asynchronous Javascript And XML:异步的JS和XML,由Google2002年在GoogleSuggest应用提出,目标实现客户端和服务器“同时”运 ...

  10. 脱离node自己使用普通的requirejs管理js资源

    首先,工程目录: 现在主页面(web框架写法.html): <!DOCTYPE html> <html lang="en"> <head> &l ...