• 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. Rails内存的问题 Java内存情况

    Rails内存的问题 Java内存情况 一个txt文件,100M,300万行,都是坐标数据: 需要进行坐标的变换.计算.比较: 在Rails中使用Ruby进行计算,会导致内存超过1.5G,最后溢出而亡 ...

  2. 【SPOJ-GSHOP】Rama and Friends【贪心】【细节】

    题意: 给出n个非严格递增的整数(可能有负数),必须操作k次.每次能够把当中一个数变为它的相反数,使得终于的数列和最大. 输出这个最大和. 考验怎样出坑数据卡自己的程序... #include < ...

  3. NOIP2017提高组模拟赛 8(总结)

    NOIP2017提高组模拟赛 8(总结) 第一题 路径 在二维坐标平面里有N个整数点,Bessie要访问这N个点.刚开始Bessie在点(0,0)处. 每一步,Bessie可以走到上.下.左.右四个点 ...

  4. nyoj--747--蚂蚁的难题(三)(dp背包)

    蚂蚁的难题(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:4 描述 蚂蚁终于把尽可能多的食材都搬回家了,现在开始了大厨计划. 已知一共有 n 件食材,每件食材有一个美味度  ...

  5. HTML5学习笔记(一):HTML5基本概念

    1.HTML的发展历程 HTML(1994年,W3C成立) HTML2(1995年) HTML3(1996年) HTML4.0(1997年) HTML4.01(1999年)——HTML5(2008年: ...

  6. Java文件(io)编程——文件字符流的使用

    案例1: 读取一个文件并写入到另一个文件中,char[] 来中转. 首先要在E盘下创建一个文本文档,命名为test.txt,输入一些字符串. public class Demo_5 { public ...

  7. RabbitMq笔记(2)

    今天收获不少,记个笔记. namespace RabbitMQTest { class Program { static void Main(string[] args) { Consumer(); ...

  8. 转js调优

    随着网络的发展,网速和机器速度的提高,越来越多的网站用到了丰富客户端技术.而现在Ajax则是最为流行的一种方式.javascript是一种解释型 语言,所以能无法达到和C/Java之类的水平,限制了它 ...

  9. 服务器搭建域控与SQL Server的AlwaysOn环境过程(四)配置AlwaysOn

    0 引言 这一篇才真正开始搭建AlwaysOn,前三篇是为搭建AlwaysOn 做准备的. 步骤 1.3 配置AlwaysOn 请先使用本地用户Administrator登录这两个集群节点并执行下面的 ...

  10. 小程序自定义tabbar

    代码片段: wechatide://minicode/IUoCyemJ7D3d GitHub: https://github.com/WozHuang/Miniprogram-Demo/tree/ma ...