一个自己实现的Vector(只能处理基本类型数据)

转载自: https://www.ev0l.art/index.php/archives/22/

  • string 类型不行

  • bool char* int double float long long 等基本类型可用

  • 使用模板类实现。底层为数组实现。

  • dvector.h

#ifndef DVECTOR_H
#define DVECTOR_H
#pragma once
#include <iostream>
template <class T>
class dvector
{
public:
dvector();
~dvector();
bool push_back(T);
void show(); public:
T* p;
int len;
int real_len; }; #endif // DVECTOR_H
  • dvector.cpp
#include "dvector.h"

template <class T>
dvector<T>::dvector()
{
len=real_len =0;
p=nullptr;
} template<class T>
dvector<T>::~dvector()
{
if(p!=nullptr)
{
delete []p;
p=nullptr;
}
} template <class T>
void dvector<T>::show()
{
if(p!=nullptr)
{
for(int i=0;i<real_len;i++){
std::cout<<i<<"\t"<<*(p+i)<<std::endl;
} std::cout<<"length="<<real_len<<std::endl;
}else { std::cout<<"NNNNNNNNNNNNNNNNNNNNNNNNNNo thing"<<std::endl;
}
} template<class T>
bool dvector<T>::push_back(T t){ if(p==nullptr)
{
//第一个为空说明只有一个元素
p=new T;
*p=t;
real_len=len=1;
}else { //第一个不为空说明有多个元素,这时候链表就必须重新分配内存
//分配为数组形式
T *ptemp = new T[real_len+1];
for(int i=0;i<real_len;i++)
{
*(ptemp+i)=*(p+i); }
*(ptemp+real_len)=t;
delete []p;
p=ptemp;
real_len+=1;
len+=1;
} return true; } int main()
{
//测试基本类型
//string 会出错,因为string 不是基本类型,是一种类似 vector 的类模板,其内部的内存操作与基本类型不一样。
//1. int
dvector<int>* dv1=new dvector<int>;
dv1->push_back(12);
dv1->push_back(15);
dv1->push_back(1995);
dv1->push_back(200);
dv1->push_back(2);
dv1->push_back(1); dv1->show(); //2. double
dvector<double>* dv2=new dvector<double>;
dv2->push_back(12.2);
dv2->push_back(15.3);
dv2->push_back(1995.0220);
dv2->push_back(200.1);
dv2->push_back(2.3);
dv2->push_back(1.9); dv2->show(); //3. char*
dvector<char*>* dv3=new dvector<char*>;
dv3->push_back("nimei");
dv3->push_back("de");
dv3->push_back("垃圾");
dv3->push_back("95");
dv3->push_back("lalala");
dv3->push_back("45"); dv3->show();
return 0;
}

晚上完善 增加了 删 改 查

- 和尹成老师视频里面写的不一样。。自己写的。反正就是不规范就是了
  • dvector.h
#ifndef DVECTOR_H
#define DVECTOR_H
#pragma once
#include <iostream>
template <class T>
class dvector
{
public:
dvector();
~dvector();
bool push_back(T);
bool del(T);
bool modify(T, T);
int search(T t);
void show(); public:
T* p;
int len;
int real_len; }; #endif // DVECTOR_H
  • dvector.cpp
#include "dvector.h"

using namespace std;

template <class T>
dvector<T>::dvector()
{
len=real_len =0;
p=nullptr;
} template<class T>
dvector<T>::~dvector()
{
if(p!=nullptr)
{
delete []p;
p=nullptr;
}
} //遍历输出
template <class T>
void dvector<T>::show()
{
if(p!=nullptr)
{
for(int i=0;i<real_len;i++){
std::cout<<i<<"\t"<<*(p+i)<<std::endl;
} std::cout<<"length="<<real_len<<std::endl;
}else { std::cout<<"NNNNNNNNNNNNNNNNNNNNNNNNNNo thing"<<std::endl;
}
} //增
template<class T>
bool dvector<T>::push_back(T t){ if(p==nullptr)
{
//第一个为空说明只有一个元素
p=new T;
*p=t;
real_len=len=1;
}else { //第一个不为空说明有多个元素,这时候链表就必须重新分配内存
//分配为数组形式
T *ptemp = new T[real_len+1];
for(int i=0;i<real_len;i++)
{
*(ptemp+i)=*(p+i); }
*(ptemp+real_len)=t;
delete []p;
p=ptemp;
real_len+=1;
len+=1;
} return true; } //查 返回查找到的序号
template <class T>
int dvector<T>::search(T t)
{
if (p ==nullptr)
{
std::cout << "The dvector is empty ,abort!" << std::endl;
return false;
}
else
{
for (size_t i = 0; i < real_len; i++)
{
if (*(p+i) == t)
{
cout << "FIND " << t << "at the position of " << i<<" " << endl;
return i; }
} cout << "no such a thing" << endl;
return -1; } return -1; } //删
template <class T>
bool dvector<T>::del(T t)
{ if (p == nullptr)
{
std::cout << "The dvector is alreafy empty ,abort!" << std::endl;
return false;
}
else
{
for (size_t i = 0; i < real_len; i++)
{
if (*(p + i) == t)
{
cout << "Deleting" << endl;
cout << "FIND " << t << "at the position of " << i << " " << endl; //如果是在第一个的情况
if (i == 0)
{
for (size_t i = 0; i < real_len; i++)
{
if (real_len == 1) //如果是只剩一个而且刚好第一个是要删除的
{
delete p;
p == nullptr;
real_len -= 1;
return true; }
else
{ //还有多个且第一个是要删除的
T* tmp = new T[real_len - 1];
for (size_t k = 0; k < real_len-1; k++)
{
*(tmp + k) = *(p + k + 1);
} delete[]p;
p = tmp;
real_len -= 1;
return true;
} } }
else if (i== real_len-1) //最后一个匹配要删除的时候
{
p + i == nullptr;
real_len -= 1;
}
else //在中间的情况
{ T* tmp = new T[real_len - 1];
for (size_t k = 0; k < i ; k++)
{
*(tmp + k) = *(p + k);
}
// 利用两个循环刚好跳过下标为i 的值 k 为原来的p 中的值,tmp+k-i 为新数组中的下标
for (size_t k = i+1; k < real_len; k++)
{
*(tmp + k - 1) = *(p + k); } delete[]p;
p = tmp;
real_len -= 1;
return true; } }
} cout << "no such a thing,Delete failed!" << endl;
return false; } } //改
template <class T>
bool dvector<T>::modify(T origin, T mo)
{ if (p == nullptr)
{
std::cout << "The dvector is empty ,abort!" << std::endl;
return false;
}
else
{
for (size_t i = 0; i < real_len; i++)
{
if (*(p + i) == origin)
{
cout << "Modifying" << endl;
cout << "FIND " << origin << "at the position of " << i << " " << endl; *(p + i) = mo; }
} cout << "no such a thing ,Modify failed!" << endl;
return false; } return -1; } int main()
{
//测试基本类型
//string 会出错,因为string 不是基本类型,是一种类似 vector 的类模板,其内部的内存操作与基本类型不一样。
//1. int
dvector<int>* dv1=new dvector<int>;
dv1->push_back(12);
dv1->push_back(15);
dv1->push_back(1995);
dv1->push_back(200);
dv1->push_back(2);
dv1->push_back(1); dv1->show(); //dv1->search(200);
//dv1->search(1000);
dv1->del(12);
dv1->show();
dv1->del(1995);
dv1->show();
dv1->del(1);
dv1->show(); dv1->modify(15, 33);
dv1->modify(200, 1);
dv1->modify(100, 1);
dv1->show(); // cout<<"next............"<<endl<<endl;
// //2. double
// dvector<double>* dv2=new dvector<double>;
// dv2->push_back(12.2);
// dv2->push_back(15.3);
// dv2->push_back(1995.0220);
// dv2->push_back(200.1);
// dv2->push_back(2.3);
// dv2->push_back(1.9);
//
// dv2->show();
//
// dv2->search(1.9);
//
// cout << "next............" << endl << endl;
//
// //3. char*
// dvector<const char*>* dv3=new dvector<const char*>;
// dv3->push_back("nimei");
// dv3->push_back("de");
// dv3->push_back("垃圾");
// dv3->push_back("95");
// dv3->push_back("lalala");
// dv3->push_back("45");
//
//dv3->show();
//dv3->search("nimei");
//cout << "next............" << endl << endl; std::cin.get();
return 0;
}

最新文章

  1. FLASH结构
  2. 1个简单的Log
  3. ajax鼠标滚动请求 或 手机往下拉请求
  4. Jquery_Ajax GET方式传递文本
  5. JVM 必备指南
  6. ORACLE no1 存储过程插入更新表数据
  7. opencv Installation in Linux and hello world
  8. 关于 rand() 函数返回值的值域的疑问
  9. 用户手册User Guide的写法
  10. 并行编程条件变量(posix condition variables)
  11. 微信公众平台企业号验证接口、回调 PHP版
  12. sealed、new、virtual、abstract与override 总结
  13. Java课程设计----仿Windows标准型计算器
  14. java基础之关键字static
  15. python Django 中间件介绍
  16. windows下面Nginx日志切割
  17. 巨坑– 膜BWV543
  18. mysql表关联
  19. C语言关于进制转换,补码, 整数的位操作
  20. Linux驱动之定时器在按键去抖中的应用

热门文章

  1. async处理异步操作
  2. spring boot 中的配置文件可以存放的位置
  3. B: 最小代价
  4. k种球若干,取n个球,输出所有取球方案 (模拟)
  5. 【转】Python中*args和**kwargs的区别
  6. SpringCloud入门——(1)创建Eureka项目
  7. 删除hdfs上的内容报错:rm: Cannot delete /wxcm/ Name node is in safe mode.
  8. java各种面试问题
  9. apply()、call()、bind()
  10. ATT&amp;CK实战系列——红队实战(一)