Myclass.h

#pragma once
#include<iostream>
#include<Windows.h>
#define SUCCESS 1 // 成功
#define ERROR -1 // 失败
#define MALLOC_ERROR -2 // 申请内存失败
#define INDEX_ERROR -3 // 错误的索引号 template <class T_ELE>
class Vector
{
public:
Vector();
Vector(DWORD dwSize);
~Vector();
public:
DWORD at(DWORD dwIndex, OUT T_ELE* pEle); //根据给定的索引得到元素
DWORD push_back(T_ELE Element); //将元素存储到容器最后一个位置
BOOL pop_back(); //删除最后一个元素
DWORD insert(DWORD dwIndex, T_ELE Element); //向指定位置新增一个元素
DWORD capacity(); //返回在不增容的情况下,还能存储多少元素
VOID clear(); //清空所有元素
BOOL empty(); //判断Vector是否为空 返回true时为空
DWORD erase(DWORD dwIndex); //删除指定元素
DWORD size(); //返回Vector元素数量的大小
private:
BOOL expand();
private:
DWORD m_dwIndex; //下一个可用索引
DWORD m_dwIncrement; //每次增容的大小
DWORD m_dwLen; //当前容器的长度
DWORD m_dwInitSize; //默认初始化大小
T_ELE* m_pVector; //容器指针
}; //构造函数(不带参数)
template <class T_ELE>
Vector<T_ELE>::Vector()
:m_dwInitSize(10), m_dwIncrement(5)
{
//1.创建长度为m_dwInitSize个T_ELE对象
m_pVector = new T_ELE[m_dwInitSize]; //2.将新创建的空间初始化
memset(m_pVector, 0, m_dwInitSize * sizeof(T_ELE)); //3.设置其他值
m_dwLen = m_dwInitSize;
m_dwIndex = 0; } //构造函数(带参数)
template <class T_ELE>
Vector<T_ELE>::Vector(DWORD dwSize)
:m_dwIncrement(5)
{
//1.创建长度为dwSize个T_ELE对象
m_pVector = new T_ELE[dwSize]; //2.将新创建的空间初始化
memset(m_pVector, 0, dwSize * sizeof(T_ELE)); //3.设置其他值
m_dwLen = dwSize;
m_dwIndex = 0;
} //析构函数
template <class T_ELE>
Vector<T_ELE>::~Vector()
{ //释放空间 delete[]
delete[] m_pVector;
m_pVector = NULL;
} template <class T_ELE>
BOOL Vector<T_ELE>::expand()
{
DWORD dwTempLen = 0;
T_ELE* pTemp = NULL;
// 1. 计算增加后的长度
dwTempLen = m_dwLen + m_dwIncrement; // 2. 申请空间
pTemp = new T_ELE[dwTempLen]; // 3. 将数据复制到新的空间
memcpy(pTemp,m_pVector,sizeof(T_ELE)*m_dwLen); // 4. 释放原来空间
delete[] m_pVector;
m_pVector = pTemp;
pTemp = NULL; // 5. 为各种属性赋值
m_dwLen = dwTempLen; return TRUE; } //将元素存储到容器最后一个位置
template <class T_ELE>
DWORD Vector<T_ELE>::push_back(T_ELE Element)
{
//1.判断是否需要增容,如果需要就调用增容的函数
if (m_dwIndex >= m_dwLen)
{
expand();
}
//2.将新的元素复制到容器的最后一个位置
memcpy(&m_pVector[m_dwIndex],&Element,sizeof(T_ELE));
//3.修改属性值
m_dwIndex++; return SUCCESS;
} //删除最后一个元素
template<class T_ELE>
BOOL Vector<T_ELE>::pop_back() {
/*if (m_dwLen > 0) {
memset(m_pVector + m_dwLen, 0, sizeof(T_ele));
m_dwLen--;
}
*/
//下面这个是删除当前元素中最后一个元素的方法,上面注释那个是删除整个容器最后一个容器
if (m_dwIndex > 0) {
memset(m_pVector + (m_dwIndex - 1), 0, sizeof(T_ELE));
m_dwIndex--;
return TRUE;
}
} //向指定位置新增一个元素
template <class T_ELE>
DWORD Vector<T_ELE>::insert(DWORD dwIndex, T_ELE Element)
{
//1.判断索引是否在合理区间
if(dwIndex<0|| dwIndex>m_dwIndex)
{
return INDEX_ERROR;
} //2.判断是否需要增容,如果需要就调用增容的函数
if(dwIndex>=m_dwLen)
{
expand();
} //3.将dwIndex只后的元素后移
for(int i = m_dwIndex;i> dwIndex;i--)
{
memcpy(&m_pVector[i], &m_dwIndex[i - 1], sizeof(T_ELE));
} //4.将Element元素复制到dwIndex位置
memcpy(&m_dwIndex[dwIndex],&Element,sizeof(T_ELE)); //5.修改属性值
m_dwIndex++;
} //根据给定的索引得到元素
template <class T_ELE>
DWORD Vector<T_ELE>::at(DWORD dwIndex, T_ELE* pEle)
{
//判断索引是否在合理区间
if (dwIndex<0 || dwIndex>=m_dwIndex)
{
return INDEX_ERROR;
} //将dwIndex的值复制到pEle指定的内存
memcpy(&pEle, &m_pVector[dwIndex], sizeof(T_ELE));
} //删除指定元素
template <class T_ELE>
DWORD Vector<T_ELE>::erase(DWORD dwIndex)
{
//1.判断索引是否在合理区间
if (dwIndex <0 || dwIndex >= m_dwIndex || dwIndex > m_dwLen)
{
return INDEX_ERROR;
} //2.将dwindex之后的元素前移
for (int i = dwIndex; i < m_dwIndex - 1; i++)
{
memcpy(&m_pVector[i], &m_pVector[i + 1], sizeof(T_ELE));
} //3.修改属性值
m_dwIndex--;
} //判断Vector是否为空 返回true时为空
template<class T_ELE>
BOOL Vector<T_ELE>::empty() {
if (m_pVector == NULL or m_dwIndex = 0) {
return true;
}
return false;
} template<class T_ELE>
DWORD Vector<T_ELE>::size() {
return m_dwLen;
} //查询剩余容量
template<class T_ELE>
DWORD Vector<T_ELE>::capacity() {
if (m_pVector)
{
return m_dwLen - m_dwIndex;
}
return ERROR;
} template<class T_ELE>
void Vector<T_ELE>::clear() {
memset(m_pVector, 0, sizeof(T_ELE) * m_dwLen);
m_dwIndex = 0;
}

Vector.cpp

#include"MyClass.h"
#include"malloc.h" void TestVector()
{
Vector<int>* pVector = new Vector<int>(5); pVector->push_back(1);
pVector->push_back(2);
pVector->push_back(3);
pVector->push_back(4);
pVector->push_back(5);
//pVector->push_back(6); pVector->erase(3); } int main(int argc, char* argv[])
{
TestVector(); return 0;
}

补充一下用vector来定义二维数组

初始化一个二维vector数组并指定大小的方法有:

1. vector<vector<int>> vec(行数, vector<int>(列数));
// 如 vector<vector<int>> vec(3,vector<int>(4)) 定义的就是3行4列(有没有想到汤家凤hhh)的二维数组 2. vector<vector<int>> vec(行数, vector<int>(列数, 初始值));
//如 vector<vector<int>> vec(3,vector<int>(4,1)) 定义的就是3行4列(有没有想到汤家凤hhh)的二维数组,并且二维数组里的数全部初始化为1 3. vector<vector<int>> vec; vec.resize(行数); vec[i].resize(列数); vec[i] = {值};
//这就说明可以定义不同行的列数不相同,可以指定某行的列数

手撕vector的更多相关文章

  1. NN入门,手把手教你用Numpy手撕NN(一)

    前言 这是一篇包含极少数学推导的NN入门文章 大概从今年4月份起就想着学一学NN,但是无奈平时时间不多,而且空闲时间都拿去做比赛或是看动漫去了,所以一拖再拖,直到这8月份才正式开始NN的学习. 这篇文 ...

  2. NN入门,手把手教你用Numpy手撕NN(2)

    这是一篇包含较少数学推导的NN入门文章 上篇文章中简单介绍了如何手撕一个NN,但其中仍有可以改进的地方,将在这篇文章中进行完善. 误差反向传播 之前的NN计算梯度是利用数值微分法,虽容易实现,但是计算 ...

  3. 手撕代码:统计1到n二进制数中1出现的总次数

    题目描述: 互娱手撕代码题. 统计从1到n这n个数的二进制表示中1出现的次数. 思路分析: 思路一:直接的做法是从1遍历到n,对于每个数和1做与操作,之后,对于这个数不断做右移操作,不断和1做与操作, ...

  4. 编译原理--05 用C++手撕PL/0

    前言 目录 01 文法和语言.词法分析复习 02 自顶向下.自底向上的LR分析复习 03 语法制导翻译和中间代码生成复习 04 符号表.运行时存储组织和代码优化复习 05 用C++手撕PL/0 在之前 ...

  5. 手撕Ford-Fulkerson algorithm 学一半的笔记

    目录 定义大概就这些 伪代码 自己做slide里的quiz 搬运别人的代码 我明白了, 余量网络 名如其名 比如你f/c=3/5 那么正边2,reverse edge3,加起来是5 在这个你建的新图上 ...

  6. Netty实现高性能IOT服务器(Groza)之手撕MQTT协议篇上

    前言 诞生及优势 MQTT由Andy Stanford-Clark(IBM)和Arlen Nipper(Eurotech,现为Cirrus Link)于1999年开发,用于监测穿越沙漠的石油管道.目标 ...

  7. 手撕RPC框架

    手撕RPC 使用Netty+Zookeeper+Spring实现简易的RPC框架.阅读本文需要有一些Netty使用基础. 服务信息在网络传输,需要讲服务类进行序列化,服务端使用Spring作为容器.服 ...

  8. 手撕公司SSO登陆原理

    Single Sign-on SSO是老生常谈的话题了,但部分同学对SSO可能掌握的也是云里雾里,一知半解.本次手撕公司的SSO登陆原理,试图以一种简单,流畅的形式为你提供 有用的SSO登陆原理. 按 ...

  9. NN入门,手把手教你用Numpy手撕NN(三)

    NN入门,手把手教你用Numpy手撕NN(3) 这是一篇包含极少数学的CNN入门文章 上篇文章中简单介绍了NN的反向传播,并利用反向传播实现了一个简单的NN,在这篇文章中将介绍一下CNN. CNN C ...

  10. 手撕ES6--Promise

    手撕ES6--Promise:https://www.jianshu.com/p/0925eae38d2c 手写一个Promise,附源码分析:https://blog.csdn.net/weixin ...

随机推荐

  1. SpringMVC——SSM整合-异常处理器

    异常处理器 出现异常的常见位置与常见诱因: 框架内部抛出的异常:因使用不合规导致 数据层抛出异常:因外部服务器故障导致(例如:服务器访问超时) 业务层抛出的异常:因业务逻辑书写错误导致(例如:遍历业务 ...

  2. 深入理解 Nuxt.js 中的 app:created 钩子

    title: 深入理解 Nuxt 中的 app created 钩子 date: 2024/9/26 updated: 2024/9/26 author: cmdragon excerpt: 摘要:本 ...

  3. U179915 关于分级火箭的一点理想化的计算

    题目地址 本题是一道疯狂推式子的玄学复杂度sb题. 解题思路 1.数学部分 ​ 首先假定已经将火箭分成了 \(n+1\) 级,记使用了 \(n\) 个分级器.记各级的开始时间点为: \[0=t_0&l ...

  4. 【USB3.0协议学习】Topic4·USB3.0的Port Connect State Machine和设备枚举

    上一节的文章[USB3.0协议学习]Topic2·USB3.0的LTSSM分析中我们详细分析了USB3.0协议中的链路训练状态机(LTSSM)的各状态和跳转条件,覆盖了所有LTSSM状态.本文我们将从 ...

  5. 【ARMv8】异常级别的定义EL0、EL1、EL2、EL3

    Exception levels ARMv8-A系列定义了一系列的异常等级,从EL0到EL3,下面具体说明其含义: ELn中,随着n的增加,软件的执行权限也相应的增加: EL0被称为无特权执行: EL ...

  6. Guava中的Joiner和Splitter

    目录 Guava 介绍 Joiner list转string map转string 处理嵌套集合 处理null值 Splitter string转list string转map 多个拆分符 输出 代码 ...

  7. 2. 王道OS-操作系统的特征,发展和分类

    1. 并发:宏观上是同时发生的,微观是交替发生的 :ps:并行:宏观和微观都是同时发生的 : ps:单核CPU同一时刻只能执行一个程序,各个程序只能并发的执行 : 多核CPU同一时刻可以同时执行多个程 ...

  8. 关于 KubeSphere IDOR 安全漏洞 CVE-2024-46528 的声明及解决方案

    近期,有第三方平台的安全技术人员发现了在 KubeSphere 开源版 3.4.1 及 4.1.1 上存在不安全的直接对象引用(IDOR)的漏洞,该漏洞允许低权限的通过认证的攻击者在没有适当授权检查的 ...

  9. 关于git的安装

    window平台下面: 步骤一: 首先去官网下载安装包: 官方链接:https://git-scm.com/download/win 至于选择32位还是64为的,各位就见仁见智了(根据自己的系统). ...

  10. JetBrains IDEs 软件全破解

    JetBrains IDE相关产品是一系列专为不同编程语言和平台设计的智能开发工具,它们可以帮助开发者提高效率,编写高质量的代码,和享受编程的乐趣.为当世最有影响力的IDE之一. JB 软件分为都分为 ...