list容器的C++代码实现
- #include <iostream>
- using namespace std;
- template <class T>
- class mylist;//前置声明
- template <class T>
- class node
- {
- friend class mylist<T>;//友元
- template <class T1>
- friend ostream& operator <<(ostream & out , node<T1> _node);
- public:
- node(T _data)
- {
- data = _data;
- next = NULL;
- prev = NULL;
- }
- private:
- T data;
- node<T> *next;//指向下一个节点
- node<T> *prev;//指向前一个节点
- };
- //输出符号 << 的重载
- template <class T>
- ostream& operator <<(ostream & out , node<T> _node)
- {
- out<<_node.data<<'\t';
- return out;
- }
- /*类名:mylist*/
- template<class T>
- class mylist
- {
- public:
- typedef bool (*Unperd)(T value);
- typedef bool (*BinPred)(T value);
- typedef bool (*Comp)(T a,T b);//排序的函数指针
- /*类名:iterator
- 作用:迭代器
- */
- class iterator
- {
- public:
- iterator()
- {
- ptr = NULL;
- }
- iterator(node<T>* _ptr)
- {
- ptr = _ptr;
- }
- /*符号 = 重载*/
- void operator =(iterator it)
- {
- this->ptr = it.ptr;
- }
- /*符号 != 重载*/
- bool operator !=(iterator it)
- {
- return this->ptr != it.ptr;
- }
- /*符号 == 重载*/
- bool operator == (iterator it)
- {
- return this->ptr == it.ptr;
- }
- /*符号 ++ 重载*/
- iterator operator ++(int i)//这里的 int i 是无意义的只是区别前++
- {
- iterator tmp;//中间迭代器变量tmp
- tmp = *this;
- this->ptr = this->ptr->next;
- return tmp;
- }
- /*符号 * 重载*/
- node<T> operator *()
- {
- return *(this->ptr);
- }
- private:
- node<T> *ptr;
- };
- /*反向迭代器*/
- //反向迭代器就是++的重载不一样,其他是一样的
- class reserve_iterator
- {
- public:
- reserve_iterator()
- {
- ptr = NULL;
- }
- reserve_iterator(node<T>* _ptr)
- {
- ptr = _ptr;
- }
- void operator =(reserve_iterator it)
- {
- this->ptr = it.ptr;
- }
- bool operator !=(reserve_iterator it)
- {
- return this->ptr != it.ptr;
- }
- bool operator == (reserve_iterator it)
- {
- return this->ptr == it.ptr;
- }
- reserve_iterator operator ++(int i)
- {
- reserve_iterator tmp;
- tmp = *this;
- this->ptr = this->ptr->prev;
- return tmp;
- }
- node<T> operator *()
- {
- return *(this->ptr);
- }
- private:
- node<T> *ptr;
- };
- /*无参缺省构造*/
- mylist()
- {
- head = NULL;
- curr = NULL;
- }
- /*list(int num,T value)
- 函数名:mylist
- 作用:创造一个list容器里面初始就有num个value值
- 参数:int num,T value
- 返回值:无
- */
- mylist(int num,T value)
- {
- head = new node<T>(value);
- curr = head;
- int i;
- node<T>* newnode = NULL;
- for (i = 0; i < num;i++)
- {
- newnode = new node<T>(value);
- curr->next = newnode;
- newnode->prev = curr;
- curr = newnode;
- newnode = NULL;
- }
- curr->next = head;//构成循环
- head->prev = curr;
- }
- /*list<T>(list)
- 函数名:mylist
- 作用:创造一个list容器里面拷贝另一个list容器的所有内容
- 参数:mylist & list
- 返回值:无
- */
- mylist(mylist & list)
- {
- node<T>* point = list.head->next;
- this->head = new node<T>(point->data);
- this->curr = this->head;
- node<T> * newnode = NULL;
- while (point != list.head)
- {
- newnode = new node<T>(point->data);
- this->curr->next = newnode;
- newnode->prev = this->curr;
- this->curr = newnode;
- newnode = NULL;
- point = point->next;
- }
- this->curr->next = this->head;
- this->head->prev = this->curr;
- }
- /*list<T>(list.begin(),list.end())
- 函数名:mylist
- 作用:创造一个list容器里面拷贝另一个list容器的所有内容
- 参数:mylist & list
- 返回值:无
- */
- mylist(iterator start,iterator end)
- {
- iterator point = start;
- head = new node<T>(*point);
- curr = head;
- node<T> * newnode = NULL;
- while (point != end)
- {
- newnode = new node<T>(*point);
- curr->next = newnode;
- newnode->prev = curr;
- curr = newnode;
- newnode = NULL;
- point++;
- }
- curr->next = head;
- head->prev = curr;
- }
- /*void assign( input_iterator start, input_iterator end );
- assign()函数以迭代器start和end指示的范围为list赋值*/
- void assign(iterator start,iterator end)
- {
- iterator point = start;
- if (NULL == head)
- {
- this->head = new node<T>(*point);
- curr = head;
- }
- else
- {
- curr = head->prev;
- }
- node<T> * newnode = NULL;
- while (point != end)
- {
- newnode = new node<T>(*point);
- curr->next = newnode;
- newnode->prev = curr;
- curr = newnode;
- newnode = NULL;
- point++;
- }
- curr->next = head;
- head->prev = curr;
- }
- /*void assign( size_type num, const TYPE &val );*/
- void assign(int num,const T & value)
- {
- if (NULL == head)
- {
- head = new node<T>(value);
- curr = head;
- }
- else
- {
- curr = head->prev;
- }
- int i;
- node<T>* newnode = NULL;
- for (i = 0; i < num;i++)
- {
- newnode = new node<T>(value);
- curr->next = newnode;
- newnode->prev = curr;
- curr = newnode;
- newnode = NULL;
- }
- curr->next = head;
- head->prev = curr;
- }
- /*back()函数返回一个引用,指向list的最后一个元素*/
- T& back()
- {
- return head->prev->data;
- }
- /*clear()函数删除list的所有元素*/
- void clear()
- {
- curr = head->next;
- head->next = NULL;
- node<T>* tmp;
- while (curr != head)
- {
- tmp = curr;
- curr = curr->next;
- head->next = curr;
- if (NULL != curr)
- {
- curr->prev = head;
- }
- free(tmp);
- tmp = NULL;
- }
- }
- /*empty()函数返回真(true)如果链表为空,否则返回假*/
- bool empty()
- {
- if (head->next == head)
- return true;
- return false;
- }
- /*起始位置*/
- iterator begin()
- {
- return iterator(head->next);
- }
- /*末尾的下一个*/
- iterator end()
- {
- return iterator(head);
- }
- /*rbegin()函数返回一个逆向迭代器,指向链表的末尾。*/
- reserve_iterator rebegin()
- {
- return reserve_iterator(head->prev);
- }
- /*rend()函数迭代器指向链表的头部。*/
- reserve_iterator rend()
- {
- return reserve_iterator(head);
- }
- /*find查找指定元素的第一个位置没找到则返回NULL*/
- iterator find(const T &value)
- {
- curr = head->next;
- int flag = 0;
- while (curr != head)
- {
- if (curr->data == value)
- {
- flag = 1;
- return iterator(curr);
- break;
- }
- curr = curr->next;
- }
- if (flag == 0)
- {
- return iterator();
- }
- }
- /*erase()函数删除以pos指示位置的元素
- iterator erase( iterator pos );*/
- iterator erase(iterator pos)
- {
- node<T>* tmp = head;
- curr = head->next;
- while (curr != head)
- {
- if (iterator(curr) == pos)
- {
- tmp->next = curr->next;
- curr->next->prev = tmp;
- return iterator(curr->next);
- free(curr);
- curr = NULL;
- break;
- }
- else
- {
- tmp = curr;
- }
- curr = curr->next;
- }
- }
- /* iterator erase( iterator start, iterator end );
- 删除start和end之间的元素。 返回值是一个迭代器,
- 指向最后一个被删除元素的下一个元素*/
- iterator erase(iterator start,iterator end)
- {
- node<T>* tmp = head;
- curr = head->next;
- while (curr != head)
- {
- if (iterator(tmp) == start)
- {
- while (iterator(curr) != end)
- {
- tmp->next = curr->next;
- curr->next->prev = tmp;
- free(curr);
- curr = NULL;
- curr = tmp->next;
- }
- return iterator(curr);
- break;
- }
- else
- {
- tmp = curr;
- }
- curr = curr->next;
- }
- }
- /*front()函数返回一个引用,指向链表的第一个元素。*/
- T & front()
- {
- return head->next->data;
- }
- /* iterator insert( iterator pos, const TYPE &val );*/
- iterator insert(iterator pos,const T& value)
- {
- node<T>* newnode = new node<T>(value);
- curr = head->next;
- while (curr != head)
- {
- if (iterator(head) == pos)
- {
- head->prev->prev->next = newnode;
- newnode->prev = head->prev->prev;
- head->prev->prev = newnode;
- newnode->next = head->prev;
- return iterator(head->prev);
- break;
- }
- if (iterator(curr) == pos)
- {
- curr->prev->next = newnode;
- newnode->prev = curr->prev;
- curr->prev = newnode;
- newnode->next = curr;
- break;
- }
- curr = curr->next;
- }
- }
- /* void insert( iterator pos, size_type num, const TYPE &val );*/
- void insert(iterator pos,int num,const T &value)
- {
- node<T>* newnode;
- curr = head->next;
- node<T>* tmp = head;
- if (iterator(head) == pos)
- {
- tmp = head->prev->prev;
- curr = head->prev;
- while (0 != num)
- {
- newnode = new node<T>(value);
- tmp->next = newnode;
- newnode->prev = tmp;
- tmp = newnode;
- newnode = NULL;
- num--;
- }
- tmp->next = curr;
- curr->prev = tmp;
- }
- else
- {
- while (curr != head)
- {
- if (iterator(curr) == pos)
- {
- while (0 != num)
- {
- newnode = new node<T>(value);
- tmp->next = newnode;
- newnode->prev = tmp;
- tmp = newnode;
- newnode = NULL;
- num--;
- }
- tmp->next = curr;
- curr->prev = tmp;
- break;
- }
- else
- {
- tmp =curr;
- }
- curr = curr->next;
- }
- }
- }
- /*pop_back()函数删除链表的最后一个元素。*/
- void pop_back()
- {
- curr = head->prev;
- node<T>* tmp = head->prev->prev;
- tmp->next = head;
- head->prev = tmp;
- free(curr);
- curr = NULL;
- }
- /*pop_front()函数删除链表的第一个元素。*/
- void pop_front()
- {
- curr = head->next;
- node<T>* tmp = head->next->next;
- head->next = tmp;
- tmp->prev = head;
- free(curr);
- curr = NULL;
- }
- /* push_back()将val连接到链表的最后*/
- void push_back(const T& value)
- {
- node<T>* newnode = new node<T>(value) ;
- if (head == NULL)
- {
- head = new node<T>(value);
- curr = head;
- }
- else
- {
- curr = head->prev;
- }
- curr->next = newnode;
- newnode->prev = curr;
- curr = newnode;
- newnode = NULL;
- curr->next = head;
- head->prev = curr;
- }
- /*push_front函数将val连接到链表的头部。*/
- void push_front(const T& value)
- {
- node<T>* newnode = new node<T>(value) ;
- if (head == NULL)
- {
- head = new node<T>(value);
- curr = head;
- curr->next = newnode;
- newnode->next = curr;
- curr = newnode;
- newnode = NULL;
- curr->next = head;
- head->prev = curr;
- }
- else
- {
- curr = head;
- newnode->next = curr->next;
- curr->next = newnode;
- curr = newnode;
- newnode = NULL;
- curr->prev = head;
- curr->next->prev = curr;
- }
- }
- /*remove()函数删除链表中所有值为val的元素*/
- void remove(const T & value)
- {
- node<T>* tmp = head;
- curr = head->next;
- while (curr != head)
- {
- if (curr->data == value)
- {
- tmp->next = curr->next;
- curr->next->prev = tmp;
- free(curr);
- curr = NULL;
- curr = tmp;
- }
- else
- {
- tmp = curr;
- }
- curr = curr->next;
- }
- }
- /*remove_if()以一元谓词pr为判断元素的依据,遍历整个链表
- 如果pr返回true则删除该元素。*/
- void remove_if(Unperd pr)
- {
- node<T>* tmp = head;
- curr = head->next;
- while (curr != head)
- {
- if (pr(curr->data))
- {
- tmp->next = curr->next;
- curr->next->prev = tmp;
- free(curr);
- curr = NULL;
- curr = tmp;
- }
- else
- {
- tmp = curr;
- }
- curr = curr->next;
- }
- }
- /*resize()函数把list的大小改变到num。被加入的多余的元素都被赋值为val*/
- void resize(int num,T value)
- {
- int record = 0;
- curr = head->next;
- iterator point;
- while (curr != head)
- {
- ++record;
- if (record == num)
- {
- point = iterator(curr);
- }
- curr = curr->next;
- }
- if (record < num)
- {
- while (record != num)
- {
- node<T>* newnode = new node<T>(value);
- curr = head->prev;
- curr->next = newnode;
- newnode->prev = curr;
- curr = newnode;
- newnode = NULL;
- curr->next = head;
- head->prev = curr;
- record++;
- }
- }
- if (record > num)
- {
- erase(point,iterator(head));
- }
- }
- /*reverse()函数把list所有元素倒转。*/
- void reverse()
- {
- mylist<T> list(*this);
- node<T>* tmp = list.head->prev;
- this->curr = this->head->next;
- while (this->curr != this->head)
- {
- this->curr->data = tmp->data;
- tmp = tmp->prev;
- this->curr = this->curr->next;
- }
- }
- /*size()函数返回list中元素的数量。*/
- int size()
- {
- curr = head->next;
- int num = 0;
- while (curr != head)
- {
- num++;
- curr = curr->next;
- }
- return num;
- }
- /*sort()函数为链表排序,默认是升序*/
- void sort()
- {
- curr = head->next;
- node<T>* tmp;
- tmp = head->next->next;
- int temp = 0;
- int n = size();
- int i = 0;
- int flag = 0;
- while (tmp != head)
- {
- if (curr->data > tmp->data)
- {
- flag = 1;
- temp = tmp->data;
- tmp->data = curr->data;
- curr->data = temp;
- }
- i++;
- curr = curr->next;
- tmp = tmp->next;
- if ((i == n-1)&&(flag == 1))
- {
- flag = 0;
- i = 0;
- curr = head->next;
- tmp = head->next->next;
- }
- }
- }
- /* void sort( Comp compfunction );
- 如果指定compfunction的话,就采用指定函数来判定两个元素的大小*/
- void sort(Comp compfunction)
- {
- curr = head->next;
- node<T>* tmp;
- tmp = head->next->next;
- int temp = 0;
- int n = size();
- int i = 0;
- int flag = 0;
- while (tmp != head)
- {
- if (compfunction(curr->data,tmp->data))
- {
- flag = 1;
- temp = tmp->data;
- tmp->data = curr->data;
- curr->data = temp;
- }
- i++;
- curr = curr->next;
- tmp = tmp->next;
- if ((i == n-1)&&(flag == 1))
- {
- flag = 0;
- i = 0;
- curr = head->next;
- tmp = head->next->next;
- }
- }
- }
- /*void splice( iterator pos, list &lst );splice()函数把lst连接到pos的位置*/
- void splice(iterator pos,mylist & list)
- {
- this->curr = this->head->next;
- node<T>* tmp = this->head;
- while (this->curr != this->head)
- {
- if (iterator(this->curr) == pos)
- {
- tmp->next = list.head->next;
- list.head->prev->next = this->curr->next;
- this->curr->next->prev = list.head->prev;
- list.head->prev = tmp;
- free(this->curr);
- this->curr = NULL;
- free(list.head);
- list.head = NULL;
- break;
- }
- else
- {
- tmp = this->curr;
- }
- this->curr = this->curr->next;
- }
- }
- /* void splice( iterator pos, list &lst, iterator del );*/
- void splice(iterator pos,mylist & list,iterator del)
- {
- this->curr = this->head->next;
- list.curr = list.head->next;
- node<T>* tmp = list.head;
- while (this->curr != this->head)
- {
- if (iterator(this->curr) == pos)
- {
- while (list.curr != list.head)
- {
- if (iterator(list.curr) == del)
- {
- this->curr->data = list.curr->data;
- tmp->next = list.curr->next;
- curr->next->prev = tmp;
- free(list.curr);
- list.curr;
- break;
- }
- else
- {
- tmp = list.curr;
- }
- list.curr = list.curr->next;
- }
- break;
- }
- this->curr = this->curr->next;
- }
- }
- /* void splice( iterator pos, list &lst, iterator start, iterator end );*/
- void splice(iterator pos,mylist & list,iterator start,iterator end)
- {
- list.curr = list.head;
- node<T>* point = list.head;
- node<T>* point1 = list.head;
- iterator it = this->erase(pos);
- while (iterator(list.curr) != start)
- {
- list.curr = list.curr->next;
- }
- point = list.curr->prev;
- while(iterator(list.curr->prev) != end)
- {
- this->insert(it,list.curr->data);
- list.curr = list.curr->next;
- }
- point1 = list.curr;
- list.erase(point,point1);
- }
- /*swap()函数交换lst和现链表中的元素*/
- void swap(mylist & list)
- {
- int flag1 = 0;//记录交换时那个链表过长需要删除
- int flag2 = 0;//这里其实只要一个标志 但是为了方便故设置两个
- mylist<T> tmp(list);
- list.curr = list.head->next;
- this->curr = this->head->next;
- while (this->curr != this->head)
- {
- if (list.curr != list.head)
- {
- list.curr->data = this->curr->data;
- list.curr = list.curr->next;
- }
- else
- {
- flag1 = 1;
- list.push_back(this->curr->data);
- }
- this->curr = this->curr->next;
- }
- if ((list.curr != list.head)&& (flag1 == 0))
- {
- list.erase(iterator(list.curr->prev),iterator(list.head));
- }
- tmp.curr = tmp.head->next;
- this->curr = this->head->next;
- while (tmp.curr != tmp.head)
- {
- if (this->curr != this->head)
- {
- this->curr->data = tmp.curr->data;
- this->curr = this->curr->next;
- }
- else
- {
- flag2 = 1;
- this->push_back(tmp.curr->data);
- }
- tmp.curr = tmp.curr->next;
- }
- if ((this->curr != this->head)&& (flag2 == 0))
- {
- this->erase(iterator(this->curr->prev),iterator(this->head));
- }
- }
- /* void unique();unique()函数删除链表中所有重复的元素。*/
- void unique()
- {
- curr = head->next->next;
- node<T>* tmp = head->next;
- while (curr != head)
- {
- if (tmp->data == curr->data)
- {
- tmp->next = curr->next;
- curr->next->prev = tmp;
- free(curr);
- curr = NULL;
- curr = tmp->next;
- }
- tmp = tmp->next;
- curr = curr->next;
- }
- }
- /* void unique( BinPred pr );
- 指定pr,则使用pr来判定是否删除*/
- void unique(BinPred pr)
- {
- curr = head->next->next;
- node<T>* tmp = head->next;
- while (curr != head)
- {
- if ((tmp->data == curr->data)&&pr(curr->data))
- {
- tmp->next = curr->next;
- curr->next->prev = tmp;
- free(curr);
- curr = NULL;
- curr = tmp->next;
- }
- tmp = tmp->next;
- curr = curr->next;
- }
- }
- private:
- node<T> *head;
- node<T> *curr;
- };
- template <class T>
- bool dis_tinet( T value)
- {
- if (9 == value)
- return true;
- return false;
- }
- template <class T>
- bool sortfunction(T a,T b)
- {
- if (a < b)
- return true;
- return false;
- }
- template <class T>
- bool unique_t( T value)
- {
- if (8 == value)
- return true;
- return false;
- }
list容器的C++代码实现的更多相关文章
- Asp.net 面向接口可扩展框架之核心容器(含测试代码下载)
新框架的容器部分终于调通了!容器实在太重要了,所以有用了一个名词叫“核心容器”. 容器为什么那么重要呢?这个有必要好好说道说道. 1.首先我们从框架名称面向接口编程说起,什么是面向接口编程?(这个度娘 ...
- Docker容器管理及代码调用
这篇文章主要讲解Docker的容器管理,实现服务的部署,以Redis为例.我用的是Utuntu16.04,所以软件直接从库中下载,库中的Docker不是最新版本.但是不影响部署,如需要最新可在官网下载 ...
- 自己实现IOC容器,java代码实现简易版IOC容器,IOC容器实现的步骤分解
一.需求 实现一个简易的IOC容器,管理Bean,从IOC容器的BeanFactory中获取实例,从而取代自己new实例的做法. 二.实现步骤分析 三.具体代码实现 自定义注解类 MyComponen ...
- laravel 服务容器的由来 代码展示
<?php /** * 目的:代码的完善来说明从 基础类的调用到 工厂类的使用 再到容器的出现的原因 * (首先要明白工厂类和容器的关系 可以理解:容器就是工厂类的升级版(为了解决类的依赖)) ...
- 微软IOC容器Unity简单代码示例3-基于约定的自动注册机制
@(编程) [TOC] Unity在3.0之后,支持基于约定的自动注册机制Registration By Convention,本文简单介绍如何配置. 1. 通过Nuget下载Unity 版本号如下: ...
- 微软IOC容器Unity简单代码示例2-配置文件方式
@(编程) 1. 通过Nuget下载Unity 这个就不介绍了 2. 接口代码 namespace UnityDemo { interface ILogIn { void Login(); } } n ...
- 微软IOC容器Unity简单代码示例1
@(编程) 1. 通过Nuget下载Unity 这个就不介绍了 2. 接口代码 namespace UnityDemo { interface ILogIn { void Login(); } } 3 ...
- Jenkins集成openshift容器中进行代码扫描
1.Dockerfile sonarDockerfile: (基础slave镜像参考上篇博文) FROM registry.it.com/openshift/jenkins-slave:latest ...
- 项目抛弃Tomcat容器,用代码启动Tomcat插件
tomato启动代码如下: package tomcat; import org.apache.catalina.connector.Connector; import org.apache.cata ...
随机推荐
- VS2012 未找到与约束ContractName Microsoft.VisualStudio.Text.ITextDocumentFactoryService
最近新换了系统还真是问题多多呀!! 系统更新补丁后打开 VS2012 ,新建C#项目的时候出现这个问题 VS2012 未找到与约束ContractName Microsoft.VisualStudio ...
- type 命令详解
type 作用: 用来显示指定命令的类型,判断出命令是内部命令还是外部命令. 命令类型: alias: 别名 keyword:关键字, shell 保留字 function:函数, shell函数 ...
- xlwt 官网的例子
from time import * from xlwt.Workbook import * from xlwt.Style import * style = XFStyle() wb = Workb ...
- 使用 JSON.parse 反序列化 ISO 格式的日期字符串, 将返回Date格式对象
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JavaScript调试技巧
熟悉工具可以让工具在工作中发挥出更大的作用.尽管江湖传言 JavaScript 很难调试,但如果你掌握了几个技巧,就能用很少的时间来解决错误和bug. 文中已经列出了14个你可能不知道的调试技巧,但是 ...
- shiro Filter--拦截器
一 shiro自带的filter:下面主要叙述顺序是 NameableFilter->OncePerRequestFilter->AdviceFilter->PathMatching ...
- Web程序员们,你准备好迎接HTML5了吗?
HTML5作为下一代的web开发标准,其特性已经慢慢地出现在主流的浏览器中,这种新的HTML将会让浏览器不必再依赖Flash.QuickTime.Silverlight等插件,也简化了原来需要大量JS ...
- 使用nginx 的反向代理 给 kibana加上basic的身份认证
第一步准备工作 准备用户名密码: 更改host文件 第二步,安装nginx ubuntu安装Nginx之后的文件结构大致为:所有的配置文件都在/etc/nginx下,并且每个虚拟主机已经安排在了/et ...
- Python的可变类型与不可变类型
Python基础知识,自己写一写比较不容易忘 Python的每个对象都分为可变和不可变,主要的核心类型中,数字.字符串.元组是不可变的,列表.字典是可变的. 对不可变类型的变量重新赋值,实际上是重新创 ...
- zxing .net 多种条码格式的生成
下载地址:http://zxingnet.codeplex.com/ zxing.net是.net平台下编解条形码和二维码的工具,使用非常方便. 本文主要说明一下多种类型条码的生成. 适用的场景,标签 ...