当前位置:网站首页>The use of list and Its Simulation Implementation
The use of list and Its Simulation Implementation
2022-07-07 11:06:00 【Exy-】
One .list iterator Use
int ar[] = { 1,2,3,4,5,6,7,8,9,0 };
int n = sizeof(ar) / sizeof(ar[0]);
//list<int> mylist(10,5);// Two way circular list with leading node
list<int> mylist(ar, ar + n);
for (const auto& e : mylist)
{
cout << e << " ";
}
cout << endl;
list<int>::iterator it = mylist.begin();
while (it != mylist.end())
{
cout << *it << " ";
++it;
}
cout << endl;
list<int>::reverse_iterator rit = mylist.rbegin();
while (rit != mylist.rend())
{
cout << *rit << " ";
++rit;
}
cout << endl;
3.list Iterator failure problem for
Two .list Built in functions for
list<int> mylist;
mylist.empty testing list Is it empty , Is to return true, Otherwise return to false
mylist.size return list Number of valid nodes in
mylist.front return list The reference to the value in the first node of
mylist.back return list Reference to the value of the last node of
3、 ... and .list Simulation Implementation
namespace ljx
{
template<class T>
struct __list_node
{
__list_node<T>* _next;
__list_node<T>* _prev;
T _data;
__list_node(const T& x=T())
:_data(x)
,_next(nullptr)
,_prev(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)
{}
T* operator->()
{
return &_node->_data;
}
T& operator*()
{
return _node->_data;
}
Self& operator++()
{
_node = _node->_next;
return *this;
}
Self& operator++(int)
{
Self tmp(*this);
//_node = _node->_next;
++(*this);
return tmp;
}
Self& operator--()
{
_node = _node->_prev;
return *this;
}
Self& operator--(int)
{
__list_iterator<T>tmp(*this);
--(*this);
return tmp;
}
bool operator!=(const Self& it)
{
return _node != it._node;
}
bool operator==(const Self& it)
{
return _node == it._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;
// Take the lead in two-way circular list
//typedef __list_iterator<T,const T&,const T * > const_iterator;
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);
}
list()
{
_head = new node;
_head->_next = _head;
_head->_prev = _head;
}
list(const list<T>& lt)
{
_head = new node;
_head->_next = _head;
_head->_prev = _head;
//const_iterator it = lt.begin();
//while (it != lt.end())
//{
// push_back(*it);
// ++it;
//}
for (auto e : lt)
{
push_back(e);
}
}
//list <T>& operator=(const list<T>& lt)
//{
// if (this != <)
// {
// clear();
// for (auto e : lt)
// {
// push_back(e);
// }
// }
// return *this;
//}
list<T>& operator=(list<T> lt)
{
swap(_head, lt._head)
return *this;
}
~list()
{
clear();
delete _head;
_head = nullptr;
}
void clear()
{
node* p = _head->_next;
while (p != _head)
{
delete(p);
}
}
void push_back(const T& x)
{
//node* tail = _head->_prev;
//node* newnode = new node(x);
//tail->_next = newnode;
//newnode->_prev = tail;
//newnode->_next = _head;
//_head->_prev = newnode;
insert(end(), x);
}
void push_front(const T& x);
void insert(iterator pos, const T& x)
{
node* cur = pos._node;
node* prev = cur->_prev;
node* newnode = new node(x);
prev->_next = newnode;
newnode->_prev = prev;
newnode->_next = cur;
cur->_prev = newnode;
}
void erase(iterator pos)
{
assert(pos != end());
{
node* cur = pos._node;
node* prev = cur->_prev;
node* next = cur->_next;
delete cur;
prev->_next = next;
next->_prev = prev;
}
}
void pop_back()
{
erase(iterator(_head->_prev));
erase(--end());
}
private:
node* _head;
};
}
边栏推荐
- 滚动踩坑--UNI_APP(八)
- What does intermediate software evaluator test
- Kitex 重试机制
- Rolling puddle Uni_ App (VIII)
- Deeply understand the characteristics of database transaction isolation
- Transaction rolled back because it has been marked as rollback-only解决
- Mysql的json格式查询
- uniCloud
- Those confusing concepts (3): function and class
- [untitled]
猜你喜欢
【pyqt】tableWidget里的cellWidget使用信号与槽机制
2021-05-21
深入理解Apache Hudi异步索引机制
JSON format query of MySQL
[pyqt] the cellwidget in tablewidget uses signal and slot mechanism
ADB utility commands (network package, log, tuning related)
Network engineer test questions and answers in May of the first half of 2022
Basic introduction of yarn and job submission process
shardingsphere分库分表示例(逻辑表,真实表,绑定表,广播表,单表)
Openinstall and Hupu have reached a cooperation to mine the data value of sports culture industry
随机推荐
Deeply understand the characteristics of database transaction isolation
书签整理-程序员常用网站导航
【亲测可行】error while loading shared libraries的解决方案
Installation and configuration of slurm resource management and job scheduling system
ADB utility commands (network package, log, tuning related)
[untitled]
滚动踩坑--UNI_APP(八)
P2788 math 1 - addition and subtraction
Some online academic report websites and machine learning videos
【STM32】实战3.1—用STM32与TB6600驱动器驱动42步进电机(一)
如何顺利通过下半年的高级系统架构设计师?
Bookmarking - common website navigation for programmers
July 10, 2022 "five heart public welfare" activity notice + registration entry (two-dimensional code)
[installation system] U disk installation system tutorial, using UltraISO to make U disk startup disk
Vscode 尝试在目标目录创建文件时发生一个错误:拒绝访问【已解决】
SQL Server knowledge gathering 9: modifying data
Laya common script commands
BUUCTF---Reverse---reverse1
Opencv installation and environment configuration - vs2017
Poj1821 fence problem solving Report