当前位置: 首页 > news >正文

【C++篇】list模拟实现

实现接口:

  1. list的无参构造、n个val构造、拷贝构造

  2. operator=重载

  3. 实现迭代器

  4. push_back()

  5. push_front()

  6. erase()

  7. insert()

  8. 头尾删

#pragma once
#include<iostream>
#include<assert.h>
using namespace std;namespace liu
{//定义list节点template<class T>struct list_node{T  _data;list_node<T>* _prev;list_node<T>* _next;list_node(const T& x=T()):_data(x),_prev(nullptr),_next(nullptr){}};template<class T,class Ref,class Ptr>struct list_iterator{typedef list_node<T>Node;typedef list_iterator<T, Ref, Ptr>Self;Node* _node;list_iterator(Node* node):_node(node){}Ref operator*(){return _node->_data;}Ptr operator->(){return &_node->_data;}Self& operator++(){_node = _node->_next;return *this;}Self& operator--(){_node = _node->_prev;return *this;}bool operator!=(const Self& s){return _node != s._node;}bool operator==(const Self& s){return _node == s._node;}};template<class T>class list{//链表存储链表节点typedef list_node<T> Node;public://实现接口typedef list_iterator<T, T&,  T*>iterator;typedef list_iterator<T, const T&, const T*> const_iterator;void empty_init(){_head = new Node();_head->_prev = _head;_head->_next = _head;}list()//无参构造{empty_init();}list(size_t n,const T& val=T())//n个val{empty_init();for (int i=0;i<n;i++){push_back(val);}}list(const list<T>& i1){empty_init();for(auto& x:i1){push_back(x);}}~list(){clear();delete _head;_head = nullptr;}void clear(){auto it = begin();while (it!=end()){it=erase(it);}}iterator begin(){return iterator(_head->_next);}const_iterator begin()const{return const_iterator(_head->_next);}iterator end(){return iterator(_head);}const_iterator end()const{return const_iterator(_head);}iterator insert(iterator pos,const T&val){Node* new_node = new Node(val);Node* cur = pos._node;Node* prev = cur->_prev;prev->_next = new_node;new_node->_prev = prev;cur->_prev = new_node;new_node->_next = cur;return iterator(new_node);}iterator erase(iterator pos){assert(pos!=end());Node* del = pos._node;Node* prev = del->_prev;Node* next = del->_next;prev->_next = next;next->_prev = prev;delete del;return iterator(next);}void pop_front(){erase(begin());}void pop_back(){erase(--end());}void swap(list<T>& i1){std::swap(_head,i1._head);}list<T>& operator=(list<T> il){swap(il);return *this;}void push_back(const T& x){/*Node* new_node = new Node(x);Node* tail = _head->_prev;tail->_next = new_node;new_node->_prev = tail;new_node->_next = _head;_head->_prev = new_node;*/insert(end(),x);}void push_front(const T& x){/*Node* new_node = new Node(x);Node* prev = _head->_next;_head->_next = new_node;new_node->_prev = _head;prev->_prev = new_node;new_node->_next = prev;*/insert(begin(), x);}private:Node* _head;//双端链表,哨兵位};template<class T>void swap(T&a,T& b){T c(a);a = b;b = c;}template<class T>void swap(list<T>& a, list<T>& b){a.swap(b);}void test1(){/*liu::list<int>i1;i1.push_back(1);i1.push_back(2);i1.push_back(3);i1.push_back(4);i1.push_front(5);i1.push_front(6);i1.push_front(7);liu::list<int>::iterator it1 = i1.begin();while (it1!=i1.end()){cout << *it1 << " ";++it1;}cout << endl;liu::list<int>::iterator it2 = i1.begin();it2=i1.erase(it2);while (it2 != i1.end()){cout << *it2 << " ";++it2;}*/liu::list<int>i1(10,1);liu::list<int>i2(10,2);liu::swap(i1, i2);for (auto x : i2){cout << x << " ";}cout << endl;for (auto x : i1){cout << x << " ";}cout << endl;}
}

相关文章:

  • SBT开源构建工具
  • 基于python+Django+Mysql的校园二手交易市场
  • 深入Java TCP流套接字编程:高效服务器构建与高并发实战优化指南​
  • Python实例题:Python应用马尔可夫链算法实现随机文本生成
  • sass,less是什么?为什么要使用他们?
  • 学员投稿:华为,ov等手机主流大厂桌面未读计数角标更新接口汇总
  • 项目三 - 任务8:实现词频统计功能
  • [论文阅读]Prompt Injection attack against LLM-integrated Applications
  • Linux 网络配置现代实践:Netplan 与 ifcfg 的全景对比与工程指南20250526
  • 炫云云渲染,构筑虚实交融的3D数字新视界
  • python(linux环境)-pickle、json、time、zipfile模块的使用
  • 【C++11】lambda表达式 || 函数包装器 || bind用法
  • Cesium 实战 26 - 自定义纹理材质 - 实际应用之飞线(抛物线)
  • HTML与Flask表单之间的关系(chatgtp提供)
  • 【每日渲美学】3ds Max橱柜材质教程:厨房高光烤漆、木纹、亚克力、亚光板材渲染优化指南
  • 智能灾备驱动数字政府转型:从合规保障到智能治理跃升
  • 人工智能的能源困境:繁荣与危机并存的未来
  • Unity---OSC(Open Sound Control)、TouchOSC Editor、创建布局
  • 31.第二阶段x64游戏实战-封包-线程发包
  • Structure-Revealing Low-Light Image Enhancement Via Robust Retinex Model论文阅读
  • 水墨风格 网站/百度知道客服
  • 完成网站的建设工作内容/品牌宣传文案范文
  • 网站icp备案咋做/宁波网站快速优化
  • 个人备案号 可以做游戏网站吗/想做一个网站
  • 做网站的收益在哪/精准获客
  • 做网站的图片需要多少钱/qq营销推广方法和手段