双向链表(未完)

双向链表-未测试(一口气写完,错很多)

#ifndef VLYFLIST_H_
#define VLYFLIST_H_
namespace vlyflist
{

    //带头尾节点的双向链表
    template <typename T>
    class VlyfList
    {
    public:
        friend class Iterator;
        //双向节点
        struct Node
        {
            Node(T& x) : data(x), prev(nullptr), next(nullptr) {}

            T data;
            Node* prev;
            Node* next;
        };
        //迭代器
        class Iteretor
        {
        public:
            Iteretor(Node* node = nullptr) : current(node) {}

            //前置++
            Iteretor& operator++()
            {
                current = current->next;
                return *this;
            }
            //后置++
            Iteretor& operator++(int)
            {
                Iteretor tmp = *this;
                ++* this;
                return tmp;
            }
            //前置--
            Iteretor& operator--()
            {
                current = current->prev;
                return *this;
            }
            //后置--
            Iteretor& operator--(int)
            {
                Iteretor tmp = *this;
                --* this;
                return tmp;
            }
            //解引用
            T& operator*() const
            {
                return current->data;
            }
            //==
            bool operator==(const Iteretor& it) const
            {
                return current == it.current;
            }
            //!=
            bool operator!=(const Iteretor& it) const
            {
                return current != it.current;
            }

        private:
            Node* current; //当前所指数据
        };
        VlyfList() : theSize(0)
        {
            init();
        }

        VlyfList(const VlyfList& l)
        {
            init();
            this->operator=(l);
        }
        ~VlyfList()
        {
            Node* tmp = head->next;
            Node* tmpnext = tmp->next;
            while (tmp != tail)
            {
                delete tmp;
                tmp = tmpnext;
                tmpnext = tmp->next;
            }
            delete head;
            delete tail;
        }
        //拷贝赋值
        VlyfList& operator=(const VlyfList& l)
        {
            if (*this == l)
                return *this;
            else
            {
                for (auto it = this->begin(); it != this->end(); ++it)
                    push_back(*it);
            }
            return *this;
        }
        //==
        bool operator==(const VlyfList& l)
        {
            return head == l.head && tail == l.tail && theSize == l.theSize;
        }
        //头插
        void push_front(T& x)
        {
            insert(1, x);
        }
        //尾插
        void push_back(T& x)
        {
            insert(size, x);
        }
        //访问第一个元素
        T& front()
        {
            return *(begin());
        }
        const T& front() const
        {
            return *(begin());
        }
        //访问最后一个元素
        T& back()
        {
            return *(--end());
        }
        const T& back() const
        {
            return *(--end());
        }
        //头删
        void push_back()
        {
            Node* p = tail->prev;
            p->prev->next = tail;
            tail->prev = p->pre;
            delete p;
            theSize--;
        }
        //尾删
        void push_front()
        {
            Node* p = head->next;
            p->next->prev = head;
            head->next = p->next;
            delete p;
            theSize--;
        }
        //删第i个节点
        void deleteI(size_t i)
        {
            Node* p = head;
            for (int i = 0; i < theSize; i++)
                p = p->next;
            p->prev->next = p->next;
            p->next->prev = p->prev;
            delete p;
            theSize--;
        }
        //第一个节点迭代器
        Iterator begin()
        {
            return Iteretor(head->next);
        }
        //tail的迭代器
        Iterator end()
        {
            return Iteretor(tail);
        }
        //向第i个位置插入节点i>0,返回新节点的迭代器
        Iteretor insert(unsigned i, T& x)
        {
            Node* p = head;
            for (int i = 0; i < theSize; i++)
                p = p->next;
            Node* newnode = new Node(x, p->prev, p);
            p->prev->next = newnode;
            p->prev = newnode;
            theSize++;
            return Iteretor(newnode);
        }
        //链表初始化
        void init()
        {
            head = new Node;
            tail = new Node;
            head->next = tail;
            tail->prev = head;
        }

        size_t size() const { return theSize; }
        bool empty() const { return theSize == 0; }
        //迭代器

    private:
        Node* head;
        Node* tail;
        size_t theSize;
    };
}
#endif

原文地址:https://www.cnblogs.com/vlyf/p/11728940.html

时间: 2024-08-30 06:43:53

双向链表(未完)的相关文章

whatweb.rb 未完待续

#!/usr/bin/env ruby #表示ruby的执行环境 =begin # ruby中用=begin来表示注释的开始 .$$$ $. .$$$ $. $$$$ $$. .$$$ $$$ .$$$$$$. .$$$$$$$$$$. $$$$ $$. .$$$$$$$. .$$$$$$. $ $$ $$$ $ $$ $$$ $ $$$$$$. $$$$$ $$$$$$ $ $$ $$$ $ $$ $$ $ $$$$$$. $ `$ $$$ $ `$ $$$ $ `$ $$$ $$' $ `$

把握linux内核设计思想系列(未完待续......)

[版权声明:尊重原创,转载请保留出处:blog.csdn.net/shallnet,文章仅供学习交流,请勿用于商业用途] 把握linux内核设计思想(一):系统调用 把握linux内核设计思想(二):硬中断及中断处理 把握linux内核设计思想(三):下半部机制之软中断 把握linux内核设计思想(四):下半部机制之tasklet 把握linux内核设计思想(五):下半部机制之工作队列及几种机制的选择 把握linux内核设计思想(六):内核时钟中断 把握linux内核设计思想(七):内核定时器和

细菌觅食优化算法:理论基础,分析,以及应用(未完)

原作者:Swagatam Das,Arijit Biswas,Sambarta Dasgupta,和Ajith Abraham  [摘 要]细菌觅食优化算法(Bacterial foraging optimization algorithm[BFOA])已经被分布式优化和控制的同行们当作一种全局性的优化算法接受.BFOA是由大肠杆菌的群体觅食行为所启发而总结出来 的.BFOA已经吸引了足够多的研究者的注意,由于它出现在解决真实世界中一些应用领域上优化问题的高效性.E.coli 的群体策略的生物基

Linux设备驱动开发学习(2):Linux设备驱动简介(未完)

(未完待续......)

[译]App Framework 2.1 (1)之 Quickstart (未完待续)

最近有移动App项目,选择了 Hybrid 的框架Cordova  和  App Framework 框架开发. 本来应该从配置循序渐进开始写的,但由于上班时间太忙,这段时间抽不出空来,只能根据心情和兴趣,想到哪写到哪,前面的部分以后慢慢补上. App Framework 前生是是叫 jqMobi 注意大家不要和 jQuery Mobile 混淆了,它们是两个不同的框架,一开始我还真混淆了0.01秒. 这里我先翻译一下Quickstart 部分,一是自己工作上用的上,二是也想顺便练练英文,最关键

数据结构与算法之--高级排序:shell排序和快速排序【未完待续】

高级排序比简单排序要快的多,简单排序的时间复杂度是O(N^2),希尔(shell)排序的是O(N*(logN)^2),而快速排序是O(N*logN). 说明:下面以int数组的从小到大排序为例. 希尔(shell)排序 希尔排序是基于插入排序的,首先回顾一下插入排序,假设插入是从左向右执行的,待插入元素的左边是有序的,且假如待插入元素比左边的都小,就需要挪动左边的所有元素,如下图所示: ==> 图1和图2:插入右边的temp柱需要outer标记位左边的五个柱子都向右挪动 如图3所示,相比插入排序

gulp 入门使用指南(未完)

其实网上有一大把入门指南了,官网上也讲得很清楚.怎么安装,有哪些方法,我在网上已经看到很多很多很多了. 可是我还是很懵逼.不能理解为什么要使用这些工具,不知道学习了这些方法该怎么用,在哪里用.光看文档是学不会的,得有实战!实战啊!我感受不到这些新技术的好处.所以最初学习的时候,我迫切地渴望能有一个人,一篇文章,能通过一个具体的项目来指引一下我.然鹅并没有.(在小公司的坏处,没有指导,突破不了,还懒) 现在我对gulp也还是懵懵哒.只能慢慢写咯. 几乎每一个前端工具都对应了它自己的配置文件,nod

高可用集群之heartbeat v2--基于CRM实现mysql高可用集群(未完)

实验说明: 本实验基于heartbeat的crm,实现对mysql服务的高可用,并没有高可用mysql的数据. 未完部分:使用hb_gui配置挂载nfs时,指定挂载选项,失败. mysql数据和配置文件放在nfs共享存储上 mysql配置文件使用--default-extra-file指定 mysql用户对nfs共享的有读写权限,nfs服务器和mysql所在服务器的mysql的id号要保持一致 在nfs服务器上 1 修改hostname # vim /etc/sysconfig/network

《Linux内核分析》MOOC课程之从迷你Linux内核角度理解进程时间轮片调度(未完)

代码分析 mypcb.h mymain.c 上面这段代码主要完成了对0号进程的初始化,即pid置为0,状态state置为0(即runnable状态),进程入口及当前进程的线程的ip指向my_process,线程的sp指向当前进程的进程堆栈,由于目前只有0号进程,所以next指针指向自己形成一个单PCB链表. 上面这段代码主要是扩充循环链表,使用memcpy()复制0号进程的状态给创建的从1号到MAX_TASK_NUM-1号进程,并与0号进程一起构成一个循环PCB链表. 上面这段代码功能是从循环P