vector 插入实现

#include<iostream>
#include<vector>
#include<map>
#include<string>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<set>
#include<queue>
#include<unordered_map>
#include<cmath>
using namespace std;
template<class T>
class CArray
{
	int st = 32;
	int size, temp;
	T* ptr;
public:
	CArray(int s = 0);
	CArray(CArray<T>& a);
	~CArray();
	void push_back(T v);
	void resize(int v);
	void Resize(int v);
	CArray<T>& operator=(const CArray<T>& a) ;
	int length() { return max(size, temp); };
	T& operator [](int i)
	{
		return ptr[i];
	}
};

template<class T>
CArray<T>::CArray(int s)
{
	resize(s);
}

template<class T>
CArray<T>::CArray(CArray<T>& a)
{
	if (!a.ptr)
	{
		ptr = NULL;
		size = 0;
		return;
	}
	ptr = new T[a.size];
	memcpy(ptr, a.ptr, sizeof(T) * a.size);
	size = a.size;
}

template<class T>
CArray<T>& CArray<T>::operator=(const CArray<T>& a)
{
	if (ptr == a.ptr)
		return *this;
	if (a.ptr == NULL)
	{
		if (ptr) delete[]ptr;
		ptr = NULL;
		size = 0;
		return *this;
	}
	if (size < a.size)
	{
		if (ptr) delete[]ptr;
		ptr = new T[a.size];
	}
	memcpy(ptr, a.ptr, sizeof(T) * a.size);
	size = a.size;
	return *this;
}

template<class T>
CArray<T>::~CArray()
{
	if (ptr) delete[]ptr;
}

template<class T>
void CArray<T>::resize(int v)
{
	if (v == 0)
		ptr = NULL;
	else
	{
		T* temptr = new T[v];
		memcpy(temptr, ptr, sizeof(T) * size);
		delete[]ptr;
		ptr = temptr;
		while (size < v)
		{
			ptr[size++] = 0;	
		}
	}
}

template<class T>
void CArray<T>::Resize(int v)
{
	T* temptr = new T[v];
	memcpy(temptr, ptr, sizeof(T) * size);
	delete[]ptr;
	ptr = temptr;
}

template<class T>
void CArray<T>::push_back(T v)
{
	if (ptr)
	{
		if (size < st)
			ptr[size++] = v;
		else
		{
			st = st * 2;
			Resize(st);
			ptr[size++] = v;
		}
	}
	else
	{
		ptr = new T[st];
		ptr[size++] = v;
	}
}

int main()
{
	CArray<double>a;
	for (int i = 0; i < 64; i++)
	{
		a.push_back(i + 0.3);
	}
	CArray<int>b;
	for (int i = 0; i < 64; i++)
	{
		b.push_back(i);
	}
	for (int i = 0; i < a.length(); i++)
	{
		cout << a[i] << " ";
	}
	cout << endl;
	CArray<int>q(73);
	q[1] = 3;
	for (int i = 0; i < q.length(); i++)
	{
		cout << q[i] << " ";
	}
	cout << endl;
	CArray<int>f;
	f = q;
	for (int i = 0; i < f.length(); i++)
	{
		cout << f[i] << " ";
	}
	CArray<int>e(f);
	for (int i = 0; i < e.length(); i++)
	{
		cout << e[i] << " ";
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C++中,可以使用vector的insert函数来插入元素。insert函数有多个重载形式,其中一个形式接受一个迭代器和一个值作为参数,将该值插入到指定位置之前。另一个形式接受一个迭代器和两个迭代器作为参数,将指定范围内的元素插入到指定位置之前。 例如,如果要在vector的末尾插入多个重复元素,可以使用fill_n函数结合insert函数来实现。首先,创建一个空的vector,然后使用fill_n函数和back_inserter函数将指定数量的重复元素插入vector的末尾。最后,使用循环遍历vector并输出结果。 以下是一个示例代码: ```cpp #include <iostream> #include <algorithm> #include <vector> using namespace std; int main() { vector<int> v; fill_n(back_inserter(v), 10, 3); for(auto c:v) { cout << c << " "; } cout << endl; } ``` 输出结果为:3 3 3 3 3 3 3 3 3 3。 在这个示例中,使用fill_n函数和back_inserter函数将值为3的元素插入到空的vector中,插入的数量为10个。然后,使用循环遍历vector并输出结果。 #### 引用[.reference_title] - *1* [c++vector插入多个重复元素](https://blog.csdn.net/weixin_42496224/article/details/125760583)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值