• myvector.h

     #pragma once
    #include <initializer_list>
    #include <iostream>
    using namespace std; template<class T>
    class myvector
    {
    public:
    myvector();
    myvector(int n);
    myvector(initializer_list<T> my);
    void show() const;
    ~myvector();
    //用于迭代
    T *begin();
    T *end();
    int arraysize();
    int memsize();
    //后插
    void push_back(T data);
    //前插
    void push_front(T data);
    //返回的是副本
    T operator[](int i) const;
    //返回的不是副本
    T &operator[](int i);
    //发现左值
    T* find(T &t);
    //发现右值
    T* find(T &&t);
    //改变一个值,传递的是右值
    void change(T *pos, T &&t);
    //改变一个值,传递的是左值
    void change(T *pos, T &t);
    void del(T &t);
    void del(T &&t);
    //找到的位置之前插入
    void insert(T &t, T &newt);
    void insert(T &&t, T &&newt); template<class T>
    friend ostream& operator <<(ostream &out, myvector<T> &myv);
    public:
    T * p;
    int memn;//内存长度
    int realn;//数组长度
    };
  • myvector.cpp
     #include "myvector.h"
    
     template<class T>
    myvector<T>::myvector():p(nullptr),memn(),realn()
    { } template<class T>
    myvector<T>::myvector(int n)
    {
    this->memn = this->realn = n;
    this->p = new T[n];
    memset(this->p, , sizeof(T)*n);
    } template<class T>
    myvector<T>::myvector(initializer_list<T> my)
    {
    this->realn = this->memn = my.size();
    this->p = new T[my.size()];
    int id = ;
    //初始化
    for (auto i : my)
    {
    this->p[id] = i;
    id++;
    }
    } template<class T>
    void myvector<T>::show() const
    {
    for (int i = ; i < realn; i++)
    {
    cout << p[i];
    }
    } template<class T>
    myvector<T>::~myvector()
    {
    if (p != nullptr)
    {
    delete[] this->p;
    }
    } template<class T>
    T * myvector<T>::begin()
    {
    return this->p;
    } template<class T>
    T * myvector<T>::end()
    {
    return this->p + this->realn;
    } template<class T>
    int myvector<T>::arraysize()
    {
    return this->realn;
    } template<class T>
    int myvector<T>::memsize()
    {
    return this->memn;
    } template<class T>
    void myvector<T>::push_back(T data)
    {
    if (this->p == nullptr || this->memn == )
    {
    p = new T;
    *p = data;
    memn = ;
    realn = ;
    }
    else if(memn == realn)
    {
    T *ptemp = new T[this->memn + ];
    memcpy(ptemp, this->p, this->realn * sizeof(T));
    *(ptemp + realn) = data;
    delete[] this->p;
    this->p = ptemp;
    realn += ;
    memn += ;
    }
    else
    {
    p[realn] = data;
    realn++;
    }
    } template<class T>
    void myvector<T>::push_front(T data)
    {
    if (this->p == nullptr || this->memn == )
    {
    p = new T;
    *p = data;
    memn = ;
    realn = ;
    }
    else if (memn == realn)
    {
    T *ptemp = new T[this->memn + ];
    memcpy(ptemp + , this->p, this->realn * sizeof(T));
    *ptemp = data;
    delete[] this->p;
    this->p = ptemp;
    realn += ;
    memn += ;
    }
    else
    {
    for (int i = ; i < realn; i++)
    {
    p[i + ] = p[i];
    }
    p[] = data;
    realn += ;
    }
    } template<class T>
    T myvector<T>::operator[](int i) const
    {
    if (i > realn)
    {
    throw ;
    }
    return this->p[i];
    } template<class T>
    T & myvector<T>::operator[](int i)
    {
    if (i > realn)
    {
    throw ;
    }
    return this->p[i];
    } template<class T>
    T * myvector<T>::find(T & t)
    {
    for (auto ib = this->begin(); ib != this->end(); ib++)
    {
    if (*it == t)
    {
    return ib;
    }
    }
    } template<class T>
    T * myvector<T>::find(T && t)
    {
    for (auto ib = this->begin(); ib != this->end(); ib++)
    {
    if (*it == t)
    {
    return ib;
    }
    }
    } template<class T>
    void myvector<T>::change(T * pos, T && t)
    {
    if (pos != nullptr)
    {
    *pos = t;
    }
    } template<class T>
    void myvector<T>::change(T * pos, T & t)
    {
    if (pos != nullptr)
    {
    *pos = t;
    }
    } template<class T>
    void myvector<T>::del(T & t)
    {
    int pos = -;
    for (int i = ; i < this->realn; i++)
    {
    if (t == *(this->p + i))
    {
    pos = i;
    break;
    }
    }
    if (pos != -)
    {
    if (pos == this->realn)
    {
    this->realn -= ;
    }
    else
    {
    for (int i = pos; i < realn-; i++)
    {
    p[i] = p[i + ];
    }
    realn -= ;
    }
    }
    } template<class T>
    void myvector<T>::del(T && t)
    {
    int pos = -;
    for (int i = ; i < this->realn; i++)
    {
    if (t == *(this->p + i))
    {
    pos = i;
    break;
    }
    }
    if (pos != -)
    {
    if (pos == this->realn)
    {
    this->realn -= ;
    }
    else
    {
    for (int i = pos; i < realn - ; i++)
    {
    p[i] = p[i + ];
    }
    realn -= ;
    }
    }
    } template<class T>
    void myvector<T>::insert(T & t, T & newt)
    {
    int pos = -;
    for (int i = ; i < this->realn; i++)
    {
    if (t == *(this->p + i))
    {
    pos = i;
    break;
    }
    } if (pos != -)
    {
    if (this->realn == this->memn)
    {
    T *ptemp = new T[this->memn + ];
    memcpy(ptemp, this->p, sizeof(T)*memn); delete[] this->p;
    this->p = ptemp;
    this->realn += ;
    this->memn += ;
    for (int i = realn - ; i >= pos; i--)
    {
    p[i + ] = p[i];
    }
    p[pos] = newt;
    }
    else
    {
    for (int i = realn - ; i >= pos; i--)
    {
    p[i + ] = p[i];
    }
    p[pos] = newt;
    this->realn += ;
    }
    } } template<class T>
    void myvector<T>::insert(T && t, T && newt)
    {
    int pos = -;
    for (int i = ; i < this->realn; i++)
    {
    if (t == *(this->p + i))
    {
    pos = i;
    break;
    }
    } if (pos != -)
    {
    if (this->realn == this->memn)
    {
    T *ptemp = new T[this->memn + ];
    memcpy(ptemp, this->p, sizeof(T)*memn); delete[] this->p;
    this->p = ptemp;
    this->realn += ;
    this->memn += ;
    for (int i = realn - ; i >= pos; i--)
    {
    p[i + ] = p[i];
    }
    p[pos] = newt;
    }
    else
    {
    for (int i = realn - ; i >= pos; i--)
    {
    p[i + ] = p[i];
    }
    p[pos] = newt;
    this->realn += ;
    }
    }
    } template<class T>
    ostream & operator<<(ostream & out, myvector<T> & myv)
    {
    for (int i = ; i < myv.realn; i++)
    {
    out << myv.p[i];
    }
    return out;
    }
  • main.cpp
     #include "myvector.h"
    #include "myvector.cpp" void main()
    {
    myvector<double> myv({ 1.1,2.2,3.3 });
    //myv.show();
    ////迭代器
    //for (auto i : myv)
    //{
    // cout << i << endl;
    //}
    myv.push_front(4.4);
    myv.push_back(5.5);
    myv.insert(2.2, 8.8);
    myv.del(2.2);
    myv.push_back(2.2);
    myv.del(2.2);
    /*for (auto ib = myv.begin(), ie = myv.end(); ib != ie; ib++)
    {
    cout << *ib << endl;
    }*/
    //cout << myv[1] << endl;
    cout << myv << endl;
    myv.show();
    cin.get();
    }

143.vector模板库的更多相关文章

  1. 35.自己实现vector模板库myvector

    myvector.h #pragma once //自己写的vector模板库 template <class T> class myvector { public: //构造 myvec ...

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

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

  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标准模板库(简介)

    标准模板库(STL,Standard Template Library)是C++标准库的重要组成部分,包含了诸多在计算机科学领域里所常见的基本数据结构和基本算法,为广大C++程序员提供了一个可扩展的应 ...

随机推荐

  1. QT-helloworld-QtCreater编写

    前言:纯代码编写helloworld,解析代码含义. 一.新建空项目 新建->其他项目->Empty qmake Project 二.修改.pro文件 打开helloworld.pro文件 ...

  2. ONGUI->NGUI->UGUI (Unity UI史)

    各GUI的介绍 ONGUI:Unity自带的绘制界面工具,它的成像原理是基于表层的,所以执行效率非常的低,并且没有提供复杂的UI的接口,就算开发者硬着头皮写上去只能让UI的执行效率更低. NGUI:第 ...

  3. jsp+jdbc实现用户登录

    1.1 创建数据库表 表名:user 字段: userid   保存用户的登录id name     用户名 password 密码 1.2 实现思路 a. 用户登录,则需要有个一个表单页,此页面可输 ...

  4. mybatis中if及concat函数的使用

  5. input上传文件获取文件后缀名+select通过text选中option

    1.input获取后缀名 var fileName = $("input[type='file']").val();//获取上传的文件(单个) var extName = file ...

  6. 池(Pool)

    #1 就是一个资源的集合,用的时候按照你的需要去取,用完了给人家放回去 #2 学编程的时候,老师给我们的解释过池的意思,大概是: 如果你喝水,你可以拿杯子去水龙头接.如果很多人喝水,那就只能排队去接. ...

  7. FreeCodeCamp初级算法部分学习

    Reverse a String 翻转字符串 先把字符串转化成数组,再借助数组的reverse方法翻转数组顺序,最后把数组转化成字符串. 你的结果必须得是一个字符串 当你完成不了挑战的时候,记得开大招 ...

  8. splay 文艺平衡树 (数据结构)

    题目大意:略 splay维护区间翻转裸题,为了减少不必要的麻烦,多插入两个点,分别是0和n+1 每次找区间的第K个值,就在splay上二分即可 顺便学了一下splay的完美建树,而且splay有一些小 ...

  9. dfs序题集

    dfs序可以维护一个子树内的信息 需要记录dfs进的时间以及所有子树都遍历完的时间 void dfs(int u, int fa) { L[u] = ++id; for(int i = head[u] ...

  10. 封装HttpClient进行http请求与https请求

    一.https忽略证书 /** * 用于进行Https请求的HttpClient * * @author joey * */ public class SSLClient { public stati ...