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

直播网站开发好做么重庆电子工程职业学院就业网官网

直播网站开发好做么,重庆电子工程职业学院就业网官网,广州网站建设找哪家,wordpress支付下载插件【C进阶六】list模拟实现 1.list的大致框架结构2.节点类3. 迭代器4.list内各种功能的实现1.push_back(正常实现)2.insert3.begin()和end()4.push_back和push_front(复用insert)5.erase6. pop_back与pop_front (复用erase)7.clear 清空数据8.swap9.无参构造10.析构函数11.含参构…

【C++进阶六】list模拟实现

  • 1.list的大致框架结构
  • 2.节点类
  • 3. 迭代器
  • 4.list内各种功能的实现
    • 1.push_back(正常实现)
    • 2.insert
    • 3.begin()和end()
    • 4.push_back和push_front(复用insert)
    • 5.erase
    • 6. pop_back与pop_front (复用erase)
    • 7.clear 清空数据
    • 8.swap
    • 9.无参构造
    • 10.析构函数
    • 11.含参构造
    • 12.拷贝构造
  • 5.const迭代器
  • 6.完整代码

1.list的大致框架结构

list是任意位置插入删除的容器,底层为带头双向循环链表
在这里插入图片描述
begin() 代表第一个结点,end()代表最后一个结点的下一个

List类基本框架以及无参构造:


template<class T>
class list
{typedef list_node<T> Node;
public:list(){_head = new Node;_head->_next =_head;_head->_prev =_head;}private:Node* _head;
}

2.节点类

节点类:

template<class T>
class list_node
{
public:T _data;list_node<T>* _next;list_node<T>* _prev;list_node(const T& x = T())//全缺省给匿名对象:_data(x),_next(nullptr),_prev(nullptr){}
};

3. 迭代器

list的迭代器底层不是简单的指针,所以我们不能像实现vector一样直接在类中定义迭代器和使用迭代器相关函数

重新写一个类的作用是将迭代器的++和- -等操作实现在此类中
因为list中的++实际上是node=node->next,list中的==符号判断的是node1->data和node2->data是否相同,如果迭代器和
list写在一个类中,实现此等操作会很麻烦

新写一个迭代器类来实现其功能:

template<class T>
struct __list_iterator
{typedef list_node<T> Node;typedef __list_iterator<T> iterator;//前加_代表内部的实现Node* _node;__list_iterator(Node* node):_node(node){}iterator& operator++()//前置++{_node = _node->_next;return *this;}iterator& operator++(int)//后置++{iterator tmp = *this;_node = _node->_next;return tmp;}iterator& operator--()//前置--{_node = _node->_prev;return *this;}iterator& operator--(int)//后置--{iterator tmp = *this;_node = _node->_prev;return tmp;}bool operator==(const iterator& it)const//等于{return _node == it._node;}bool operator!=(const iterator& s)//不等于{return _node != s._node;}T& operator*()//解引用{return _node->_data;}T* operator->(){return &(operator*());}
}

4.list内各种功能的实现

1.push_back(正常实现)

	void push_back(const T& x)//尾插{Node* newnode = new node(x);Node* tail = _head->_prev;tail->_next = newnode;newnode->_prev = tail;newnode->_next = _head;_head->_prev = newnode;}

2.insert

	iterator insert(iterator pos,const T&x)//在pos位置前插入{Node* temp = pos._node;Node* prev = temp->_prev;Node* newnode = new node(x);prev->_next = newnode;newnode->_prev = prev;newnode->_next = temp;temp->_prev = newnode;return iterator(newnode);//匿名对象}

3.begin()和end()

	iterator begin(){//iterator tmp(_head->_next);//return tmp;return iterator(_head->_next);//使用了匿名对象}iterator end(){//iterator tmp(_head);//return tmp;return iterator(_head);}

4.push_back和push_front(复用insert)

	void push_back(const T& x)//尾插{insert(end(), x);}
	void push_back(const T& x)//头插{insert(begin(), x);}

5.erase

	iterator erase(iterator pos)//删除pos位置{assert(pos != end());//头节点不可以删除node* cur = pos._node;node* prev = cur->_prev;node* next = cur->_next;prev->_next = next;next->_prev = prev;delete cur;return iterator(next);}

6. pop_back与pop_front (复用erase)

	void pop_back()//尾删{erase(--end());}void pop_front()//头删{erase(begin());}

7.clear 清空数据

	void clear()//清空数据{//注意不要把head清掉iterator it = begin();while (it != end()){it = erase(it);//为了防止迭代器失效设置返回值//返回值为当前节点的下一个}}

8.swap

	void swap(list<T>& x){std::swap(_head, x._head);}

9.无参构造

	void emptyinit()//创建并初始化哨兵位的头节点,方便给构造和拷贝构造复用{_head = new Node;_head->_next = _head;_head->_prev = _head;}list()//无参构造{emptyinit();}

10.析构函数

	~list()//_head也要被删除掉{clear();delete _head;_head = nullptr;}

11.含参构造

	template<class InputIterator>//有参的构造list(InputIterator first, InputIterator last)//可以用vector的迭代器来构造,也可以用栈和队列的迭代器来构造,设计成一个模板{emptyinit();while (first != last){push_back(*first);first++;}}

12.拷贝构造

	list(const list<T>& lt)//完成深拷贝{emptyinit();//创建并初始化头节点list<T> tmp(lt.begin(), lt.end());//用lt的迭代器区间去构造一下swap(tmp);//swap(_head, tmp._head)}

5.const迭代器

T*指针的可读可写可由iterator迭代器模拟
const T*指针的只读不能const iterator模拟,这样写导致迭代器本身不能修改

第一种方式:写一个新的类
我们需要单独实现一个新的类叫做const_iterator模拟const T*

template<class T>
struct __list_const_iterator
{typedef list_node<T> Node;typedef __list_const_iterator iterator;Node* _node;__list_const_iterator(Node* node):_node(node){}//......
}template<class T>
class list
{typedef list_node<T> Node;
public:typedef __list_iterator<T> iterator;typedef __list_const_iterator<T> const_iterator;//......
private:Node* _head;
}

第二种方式:复用普通迭代器(不需要写两份类)

同一个类模板,实例化参数不同,就是完全不同的类型

改进后的迭代器 和 list类:

template<class T, class Ref, class Ptr>//T,T&,T*
struct __list_iterator//迭代器不需要析函数
{typedef list_node<T> node;typedef __list_iterator<T,T&,T*> iterator;Node* _node;__list_iterator(Node* node):_node(node){}typedef Ptr pointer;typedef Ref reference;iterator& operator++()//前置++{_node = _node->_next;return *this;}iterator& operator++(int)//后置++{iterator tmp = *this;_node = _node->_next;return tmp;}iterator& operator--()//前置--{_node = _node->_prev;return *this;}iterator& operator--(int)//后置--{iterator tmp = *this;_node = _node->_prev;return tmp;}bool operator==(const iterator& it)const//等于{return _node == it._node;}bool operator!=(const iterator& s)const//不等于{return _node != s._node;}Ref operator*()//解引用{return _node->_data;}Ptr operator->(){return &(operator*());}
};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;const_iterator begin()const{return const_iterator(_head->_next);}iterator begin(){return iterator(_head->_next);//使用了匿名对象}const_iterator end()const{return const_iterator(_head);}iterator end(){return iterator(_head);}//......
private:Node* _head;
};

6.完整代码

#pragma once
#include<iostream>
#include<assert.h>
using namespace std;template<class T>
class list_node
{
public:T _data;list_node<T>* _next;list_node<T>* _prev;list_node(const T& x = T())//全缺省给匿名对象:_data(x),_next(nullptr),_prev(nullptr){}
};
template<class T, class Ref, class Ptr>//T,T&,T*
struct __list_iterator//迭代器不需要析函数
{typedef list_node<T> node;typedef __list_iterator<T,T&,T*> iterator;Node* _node;__list_iterator(Node* node):_node(node){}typedef Ptr pointer;typedef Ref reference;iterator& operator++()//前置++{_node = _node->_next;return *this;}iterator& operator++(int)//后置++{iterator tmp = *this;_node = _node->_next;return tmp;}iterator& operator--()//前置--{_node = _node->_prev;return *this;}iterator& operator--(int)//后置--{iterator tmp = *this;_node = _node->_prev;return tmp;}bool operator==(const iterator& it)const//等于{return _node == it._node;}bool operator!=(const iterator& s)const//不等于{return _node != s._node;}Ref operator*()//解引用{return _node->_data;}Ptr operator->(){return &(operator*());}
};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;const_iterator begin()const{return const_iterator(_head->_next);}iterator begin(){return iterator(_head->_next);//使用了匿名对象}const_iterator end()const{return const_iterator(_head);}iterator end(){return iterator(_head);}iterator insert(iterator pos,const T&x)//在pos位置前插入{Node* temp = pos._node;Node* prev = temp->_prev;Node* newnode = new node(x);prev->_next = newnode;newnode->_prev = prev;newnode->_next = temp;temp->_prev = newnode;return iterator(newnode);//匿名对象}void push_back(const T& x)//尾插{insert(end(), x);}void push_back(const T& x)//头插{insert(begin(), x);}iterator erase(iterator pos)//删除pos位置{assert(pos != end());//头节点不可以删除node* cur = pos._node;node* prev = cur->_prev;node* next = cur->_next;prev->_next = next;next->_prev = prev;delete cur;return iterator(next);}void pop_back()//尾删{erase(--end());}void pop_front()//头删{erase(begin());}void clear()//清空数据{//注意不要把head清掉iterator it = begin();while (it != end()){it = erase(it);//为了防止迭代器失效设置返回值//返回值为当前节点的下一个}}void swap(list<T>& x){std::swap(_head, x._head);}void emptyinit()//创建并初始化哨兵位的头节点,方便给构造和拷贝构造复用{_head = new Node;_head->_next = _head;_head->_prev = _head;}list()//无参构造{emptyinit();}~list()//_head也要被删除掉{clear();delete _head;_head = nullptr;}template<class InputIterator>//有参的构造list(InputIterator first, InputIterator last)//可以用vector的迭代器来构造,也可以用栈和队列的迭代器来构造,设计成一个模板{emptyinit();while (first != last){push_back(*first);first++;}}list(const list<T>& lt)//完成深拷贝{emptyinit();//创建并初始化头节点list<T> tmp(lt.begin(), lt.end());//用lt的迭代器区间去构造一下swap(tmp);//swap(_head, tmp._head)}
private:Node* _head;
};

文章转载自:

http://ldswGiIL.xqcgb.cn
http://d95RqOlr.xqcgb.cn
http://ADKNz3Eu.xqcgb.cn
http://tBLsK8zX.xqcgb.cn
http://4x8r34Xj.xqcgb.cn
http://c0DE6oWB.xqcgb.cn
http://4rY5QB3z.xqcgb.cn
http://CCcESBeQ.xqcgb.cn
http://VkvY3C8a.xqcgb.cn
http://fvwjqvX3.xqcgb.cn
http://oAnHY3q9.xqcgb.cn
http://nYlxwXGj.xqcgb.cn
http://6Wp0uLpl.xqcgb.cn
http://tbpJLdRQ.xqcgb.cn
http://J7IOeiSb.xqcgb.cn
http://iJBG9s8c.xqcgb.cn
http://VIeqJFgK.xqcgb.cn
http://I88h3UYb.xqcgb.cn
http://Ghnt7Pvd.xqcgb.cn
http://AdiTKWQB.xqcgb.cn
http://DzENope3.xqcgb.cn
http://8YFKD0at.xqcgb.cn
http://TZsctdHU.xqcgb.cn
http://3fggVXdM.xqcgb.cn
http://7su74rce.xqcgb.cn
http://91BCuBz5.xqcgb.cn
http://TJrscpNM.xqcgb.cn
http://C1BziSL5.xqcgb.cn
http://HxGlDjlT.xqcgb.cn
http://DYVpEyzA.xqcgb.cn
http://www.dtcms.com/wzjs/693361.html

相关文章:

  • 郑州企业网站快速优化价格广州seo排名外包
  • 网站设计对网站搜索引擎友好性的影响雄安专业网站建设电话
  • 做苗木免费网站龙华响应式网站建设
  • 万网漳州优化网站建设
  • 潍坊在线制作网站如何绑定网站域名解析
  • 网站建设与管理pdf网页设计与制作 pdf
  • 信息行业网站建设申请做网站
  • 做网站必须搭框架么wordpress文章不能添加标签
  • 永康网站建设zjyuxun什么是主页
  • hi宝贝网站建设那家好wordpress切换语言 语言包
  • 网站 建设 语言合肥有哪些做网站的公司
  • 做网站赚钱 百度网盟做网站题材
  • 哪些公司做网站维护的杭州微网站建设
  • 域名通过了才可以做网站吗东莞建设网 东莞市住房和城乡建设局门户网站
  • 用网站做微信公众号ui设计培训班排名
  • 网站开发毕业设计答辩静态网站怎么维护
  • 南京做网站的公司郑州专业网站建设搭建公司
  • 用ps做网站首页顶部图片wordpress微信 缩略图不显示
  • 企业营销型网站建设品牌中国移动的5G网站建设给了谁
  • 免费建站的网站99海南建设培训网站
  • 云阳一平米网站建设网站开发使用什么技术
  • 城市文明建设网站logo在线设计软件
  • h5网站不利于优化吗广东省建设工程交易中心网站
  • 买网站做淘宝客小型网站设计
  • 物流网站建设策划书的总结杭州软件开发制作
  • phpcms 怎么做视频网站开发和研发的区别
  • 付费推广网站工作是工作
  • 宁德城乡建设网站搭建织梦网站视频教程
  • 怎么向企业推销网站建设网页制作教程哔哩哔哩
  • 网站桥页怎么找河南省住房和建设厅安监站网站