• 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. [HTML5] Inlining images with SVG and data URIs

    The main reason you want to do I"nlining images with SVG and data URIs" is to reduce http ...

  2. Android自己定义组件系列【4】——自己定义ViewGroup实现双側滑动

    在上一篇文章<Android自己定义组件系列[3]--自己定义ViewGroup实现側滑>中实现了仿Facebook和人人网的側滑效果,这一篇我们将接着上一篇来实现双面滑动的效果. 1.布 ...

  3. 2.windows下安装git

    转自:https://blog.csdn.net/lvkelly/article/details/54666868

  4. BZOJ 2179 FFT模板

    思路:FFT板子题 //By SiriusRen #include <cstdio> #include <complex> using namespace std; typed ...

  5. KafkaZookeeper1-整体介绍

    版本 1.0.0 概述 本文介绍了 kafka 中 zookeeper 的整体实现. 最初 kafka 使用同步的方式访问 zookeeper.但是对于 partition 个数很多的cluster, ...

  6. Codeforces 723D. Lakes in Berland

    解题思路: 1.dfs所有的水,顺便计数大小并判断是不是湖. 2.如果是湖,将大小和坐标存下来. 3.对湖按大小从小到大排序. 4.dfs前(湖的数量-k)个湖,用*填充这些湖. 代码: #inclu ...

  7. 51nod 1448 二染色问题 (逆向考虑)

    题目: 注意,这题不是把一块区域的黑翻成白.白翻成黑. 是把一块区域全部翻成白或者翻成黑. 初始为全白,看能否翻出题中的情况. 我们假设翻转若干次能得到图中的形状,那么我们找出最后一次的翻转,即全W或 ...

  8. POJ 3617 Best Cow Line 贪心算法

    Best Cow Line Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 26670   Accepted: 7226 De ...

  9. Hadoop-2.4.1 ubuntu集群安装配置教程

    一.环境 系统: Ubuntu 14.04 32bit Hadoop版本: Hadoop 2.4.1 (stable) JDK版本: 1.7 集群数量:3台 注意事项:我们从Apache官方网站下载的 ...

  10. 30 个实例详解 ,让运维彻底搞清TOP 命令!

    Linux中的top命令显示系统上正在运行的进程.它是系统管理员最重要的工具之一.被广泛用于监视服务器的负载.在本篇中,我们会探索top命令的细节.top命令是一个交互命令.在运行top的时候还可以运 ...