35.自己实现vector模板库myvector
- 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的更多相关文章
- c++转载系列 std::vector模板库用法介绍
来源:http://blog.csdn.net/phoebin/article/details/3864590 介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作 ...
- 143.vector模板库
myvector.h #pragma once #include <initializer_list> #include <iostream> using namespace ...
- C++ 标准模板库(STL)——容器(Containers)的用法及理解
C++ 标准模板库(STL)中定义了通用的模板类和函数,这些模板类和函数可以实现多种流行和常用的算法和数据结构,如向量(vector).队列(queue).栈(stack).set.map等.这次主要 ...
- 标准模板库(STL)学习探究之vector容器
标准模板库(STL)学习探究之vector容器 C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...
- C++STL模板库序列容器之vector
目录 STL之Vecter 一丶STL简介 二丶Vector用法 1.vector容器的使用 2.vector迭代器. 3.vector中的方法. 三丶常用算法 1.常见算法中的算法方法. 2.sor ...
- C++标准模板库(STL)之Vector
在C中,有很多东西需要自己实现.C++提供了标准模板库(Standard Template Libray,STL),其中封装了很多容器,不需要费力去实现它们的细节而直接调用函数来实现功能. 具体容器链 ...
- C++的标准模板库STL中实现的数据结构之顺序表vector的分析与使用
摘要 本文主要借助对C++的标准模板库STL中实现的数据结构的学习和使用来加深对数据结构的理解.即联系数据结构的理论分析和详细的应用实现(STL),本文是系列总结的第一篇,主要针对线性表中的顺序表(动 ...
- C++:标准模板库vector
一:介绍 vector是C++标准模板库,是一个容器,底层是数组,为连续内存. 命名空间为std,所属头文件为<vector> 注意:不是<vector.h> vector ...
- 标准模板库(STL)学习指南之sort排序
对于程序员来说,数据结构是必修的一门课.从查找到排序,从链表到二叉树,几乎所有的算法和原理都需要理解,理解不了也要死记硬背下来.幸运的是这些理论都已经比较成熟,算法也基本固定下来,不需要你再去花费心思 ...
随机推荐
- unity3d进程通信利用WM_COPYDATE和HOOK
hello,近期用unity做了进程通信,应该是和c++的PC端实现通信,才開始一头雾水,后来实现了才知道好繁杂......先感谢对我提供帮助的百度,谷歌以及游戏圈的大大们. 在进程通信中非常多方法, ...
- Struts2中的异步提交(ajaxfileupload异步上传(图片)插件的使用)
server端採用struts2来处理文件上传. 所需环境: jquery.js ajaxfileupload.js struts2所依赖的jar包 及struts2-json-plugin-2.1. ...
- 使用docker搭建hadoop分布式集群
使用docker搭建部署hadoop分布式集群 在网上找了非常长时间都没有找到使用docker搭建hadoop分布式集群的文档,没办法,仅仅能自己写一个了. 一:环境准备: 1:首先要有一个Cento ...
- java.lang.ClassNotFoundException: org.jaxen.JaxenException
java.lang.ClassNotFoundException: org.jaxen.JaxenException java.lang.ClassNotFoundException: org.jax ...
- UVA - 10229 Modular Fibonacci 矩阵快速幂
Modular Fibonacci The Fibonacci numbers (0, 1, 1, 2, 3, 5, 8, 13, 21, 3 ...
- Another app is currently holding the yum lock; waiting for it to exit…
yum被锁定无法使用,错误信息截图如下:解决方法:rm -rf /var/run/yum.pid 来强行解除锁定,然后你的yum就可以运行了
- [hihocoder #1384] Genius ACM 解题报告(倍增)
题目链接:http://hihocoder.com/problemset/problem/1384 题目大意: 给定一个整数 M,对于任意一个整数集合 S,定义“校验值”如下: 从集合 S 中取出 M ...
- ORACLE 11g RAC-RAC DG Duplicate 搭建(生产操作文档)
环境:rhel 6.7 64位源库:ORACLE 11204 RAC 未打PSU备库:ORACLE 11204 RAC PSU 20170718 一.停止中间件并做全库备份 1.在节点2做全备 2.首 ...
- crontab任务调度
基本语法 crontab [选项] 选项: -e: 编辑crontab定时任务 -l: 查询crontab任务 -r: 删除当前用户所有的crontab任务 2)参数说明 [root ...
- springMVC下ajax获取后台参数直接走错误或者报406错误问题解决
直接走错误: 返回的结果是否json化,直接返回非字符串的结果会走ajax的error函数. 报406错误: 我在学习springmvc过程中(我的项目是配置的后缀是.html),从controlle ...