C++QT day7

仿照vector手动实现自己的myVector,最主要实现二倍扩容功能

#include <iostream>using namespace std;template<typename T>
class my_vector
{int size;//可存储的容量大小int num;//当前存储的元素个数T* data;//存储数据的空间地址public://无参构造函数my_vector();//有参构造函数my_vector(int n, const T m);//析构函数~my_vector();//拷贝构造my_vector(const my_vector &other);//返回当前的容器大小int get_capacity();//获取容器中的元素个数int get_size();//判空函数bool empty();//添加函数void push_back(const T &val);//向容器中赋值void assign(int n,const T &val);//访问容器中的元素T& at(int loc);//清空容器中的元素void clear();//删除最后一个元素void pop_back();//返回起始位置的引用T& front();//返回最后一个位置的引用T& back();//返回第一个位置的迭代器T* begin();//返回末尾下一个位置的迭代器T* end();//任意插入T* insert(T* p, const T& n);//遍历void show();
};
int main()
{my_vector<int> s1;s1.assign(7,1);cout<<"最大容量"<<s1.get_capacity()<<endl;cout<<"最后一个元素 "<<s1.at(6)<<endl;s1.insert(s1.end(),4);cout<<"最后一个元素 "<<s1.back()<<endl;cout<<"共有元素"<<s1.get_size()<<endl;cout<<"最后一个元素 "<<s1.at(8)<<endl;s1.show();cout<<"最大容量"<<s1.get_capacity()<<endl;s1.pop_back();s1.show();return 0;
}//无参构造
template<typename T>
my_vector<T>::my_vector()
{size=6;num=0;data = new T[6];
}//有参构造
template<typename T>
my_vector<T>::my_vector(int n, const T m)
{size = n;num = n;data = new T[n];for(int i=0;i<n;i++){data[i]= m;}
}template<typename T>
my_vector<T>::~my_vector()
{delete []data;
}//拷贝构造
template<typename T>
my_vector<T>::my_vector(const my_vector &other)
{size = other.size;num  = other.num;data = new T[size];for(int i=0;i<other.num;i++){data[i] = other.data[i];}
}//当前容器的大小
template<typename T>
int my_vector<T>::get_capacity()
{return size;
}template<typename T>
int my_vector<T>::get_size()
{return num;
}//判空函数
template<typename T>
bool my_vector<T>::empty()
{if(0 == num){return true;}elsereturn false;
}//添加函数
template<typename T>
void my_vector<T>::push_back(const T &val)
{if(num<size){data[num] = val;num++;}else{T *temp = new T[2*size];size = 2*size;for(int i=0;i<num;i++){temp[i] = data[i];}delete []data;//释放旧的空间data = temp;//指向新的空间temp = nullptr;data[num] = val;num++;}
}//向容器中赋值
template<typename T>
void my_vector<T>::assign(int n, const T &val)
{//判断赋值的个数是否超过最大容量if(n>size){delete [] data;data = nullptr;data = new  T [n];size = n;num = n;//赋值for(int i=0;i<n;i++){data[i] = val;}}else{num=n;for(int i=0;i<n;i++){data[i] = val;}}
}//访问元素
template<typename T>
T& my_vector<T>::at(int loc)
{if(loc > num || loc < 0){throw T(1);//越界异常}else{return data[loc-1];}
}//清空所有元素
template<typename T>
void my_vector<T>::clear()
{while (!empty()){pop_back();}}//删除末尾元素
template<typename T>
void my_vector<T>::pop_back()
{if(!empty()){data[num-1] = 0;num--;}elsereturn ;
}//返回第一个位置的引用
template<typename T>
T &my_vector<T>::front()
{return data[0];
}//返回最后一个位置的引用
template<typename T>
T &my_vector<T>::back()
{return data[num-1];
}//返回第一个位置的迭代器
template<typename T>
T *my_vector<T>::begin()
{return &data[0];
}//返回末尾下一个位置的迭代器
template<typename T>
T *my_vector<T>::end()
{return &data[num];
}//任意插入
template<typename T>
T *my_vector<T>::insert(T *p, const T &n)
{int j = 0;while(&data[0]+j != p) //寻找输入的是第几个数据的地址{j++;}if(num == size) //判断当前是否已满{int i = 0;T* data_new = new T[size*2];  //二倍扩容size = size * 2;while(i < num)       //将旧区的数据内容赋给新区{data_new[i] = data[i];i++;}delete []data;          //释放旧区data = data_new;        //指向新区data_new = nullptr;     //新指针置空//将指定位置之后的数据全都后移一位for(int k = num,i = j;i < num;i++,k--){data[k] = data[k-1];}data[j] = n;     //插入元素num++;               //存储数量加1return &data[j];}else if(num < size){//将指定位置之后的数据全都后移一位for(int k = num,i = j;i < num;i++,k--){data[k] = data[k-1];}data[j] = n;     //插入元素num++;               //存储数量加1return &data[j];}
}//遍历
template<typename T>
void my_vector<T>::show()
{int i = 0;for(;i < num;i++){cout << data[i] << "\t";}cout << endl;
}

思维导图:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/110017.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【开发】视频监控平台EasyCVR分组批量绑定/取消通道功能的后端代码设计逻辑介绍

视频监控平台/视频存储/视频分析平台EasyCVR基于云边端一体化管理&#xff0c;可支持视频实时监控、云端录像、云存储、磁盘阵列存储、回放与检索、智能告警、平台级联等功能。安防监控平台在线下场景中应用广泛&#xff0c;包括智慧工地、智慧工厂、智慧校园、智慧社区等等。 …

新手如何开始Microstation CE版二次开发

一步步学习MicroStation CE MDL&#xff08;C&#xff09;开发 - 技术资料库 - Bentley 中国优先社区 - Bentley Communities https://communities.bentley.com/communities/other_communities/chinafirst/w/chinawiki/57704/microstation-ce-mdl-c一步步学习MicroStation CE A…

SetWindowDisplayAffinity 函数设置窗体透明

#define WDA_NONE 0x00000000 #define WDA_MONITOR 0x00000001 #define WDA_EXCLUDEFROMCAPTURE 0x00000011 c#调用示例 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.L…

企业架构LNMP学习笔记50

aof默认是不开的。备份频率是更高的。 aof备份的频率&#xff1a; appendfsync always&#xff1a; 每次收到写命令就立即强制写入磁盘&#xff0c;最慢的&#xff0c;但是保证完全持久化&#xff0c;不推荐使用。 appendfsync everysec&#xff1a; 每秒强制写入磁盘一次&a…

模电2023.9.16

1、放大电路模型 根据功能基本可分为四大类&#xff1a; 电压放大、电流放大、互阻放大和互导放大。 注&#xff1a;互阻放大&#xff1a;电流信号转换为电压信号 互导放大&#xff1a;电压信号转换为电流信号 菱形的电源受控源&#xff0c;圆形的为非受控源 如何区分? 看输入…

学信息系统项目管理师第4版系列07_项目管理知识体系

1. 项目管理原则 1.1. 勤勉、尊重和关心他人 1.1.1. 关键点 1.1.1.1. 关注组织内部和外部的职责 1.1.1.2. 坚持诚信、关心、可信、合规原则 1.1.1.3. 秉持整体观 1.1.2. 职责 1.1.2.1. 诚信 1.1.2.2. 关心 1.1.2.3. 可信 1.1.2.4. 合规 1.2. 营造协作的项目管理团队…

【C++】红黑树插入操作实现以及验证红黑树是否正确

文章目录 前言一、红黑树的插入操作1.红黑树结点的定义2.红黑树的插入1.uncle存在且为红2.uncle不存在3.uncle存在且为黑 3.完整代码 二、是否为红黑树的验证1.IsBlance函数2.CheckColor函数 三、红黑树与AVL树的比较 前言 红黑树&#xff0c;是一种二叉搜索树&#xff0c;但在…

了解消息中间件的基础知识

为什么要使用消息中间件&#xff1f; 解耦&#xff1a;消息中间件可以使不同的应用程序通过解耦的方式进行通信&#xff0c;减少系统间的依赖关系提供异步通信&#xff1a;消息中间件可以实现异步消息传递&#xff0c;提高系统的响应性能。流量削峰&#xff1a;消息中间件可以…

Rust :与C交互

rust调用C端的库函数&#xff0c;有很多方法。今天介绍通过cc库的方式&#xff0c;实现rust调用c端库函数。 1、相关准备&#xff1a; 在ffi目录下&#xff0c;创建了c_part和rust_ffi文件夹。 c_part下放了ctools.c文件&#xff0c;里面有一些库函数&#xff0c;需要让rust调…

四川百幕晟科技:提升店铺质量方法是什么?

抖店是抖音旗下的移动电子商务平台&#xff0c;为商家提供在线销售和促销的机会。在抖店&#xff0c;经验值是商家评价和信誉的重要指标之一。反映了平台上商户的服务质量和用户满意度。那么&#xff0c;如何查看自己在抖店手机上的体验分数呢&#xff1f; 1、如何查看抖店手机…

【数据结构】堆排序详解

文章目录 一、堆排序思想二、向上调整建堆排序三、向下调整建堆排序四、总结 对于什么是堆&#xff0c;堆的概念分类以及堆的向上和向下两种调整算法可见&#xff1a; 堆的创建 一、堆排序思想 int a[] { 2,3,5,7,4,6 };对于这样一个数组来说&#xff0c;要想要用堆排序对它…

脚本:用python实现五子棋

文章目录 1. 语言2. 效果3. 脚本4. 解读5. FutureReference 1. 语言 Python 无环境配置、无库安装。 2. 效果 以第一回合为例 玩家X 玩家0 3. 脚本 class GomokuGame:def __init__(self, board_size15):self.board_size board_sizeself.board [[ for _ in range(board_…