美文网首页
数组模拟单链表,双链表

数组模拟单链表,双链表

作者: 风之羁绊 | 来源:发表于2019-07-22 22:44 被阅读0次

    单链表
    双链表
    这两道题有一种好写的写法,就是左右建立哨兵,然后就不需要考虑边界,数组模拟链表我还是习惯性写结构体带next的写法,更容易理解吧。

    #include<iostream>
    using namespace std;
    int m,idx;
    const int N=100005;
    struct node
    {
        int val,next;
    }a[N];
    
    void init()
    {
        a[0].next=1;
        idx=2;
    }
    //在第k个数右边插入x
    void insert(int k,int x)
    {
        a[idx].val=x;
        a[idx].next=a[k].next;
        a[k].next=idx++;
    }
    
    void del(int k)
    {
        a[k].next=a[a[k].next].next;
    }
    
    int main()
    {
        init();
        string s;
        int x,k;
        cin>>m;
        while(m--)
        {
            cin>>s;
            if(s=="H")
            {
                cin>>x;
                insert(0,x);
            }
            else if(s=="D")
            {
                cin>>k;
                if(k==0)
                    del(0);
                else
                    del(k+1);
            }
            else
            {
                cin>>k>>x;
                insert(k+1,x);
            }
        }    
        for(int i=a[0].next;i!=1;i=a[i].next)
        {
            cout<<a[i].val<<" ";
        }
        cout<<endl;
    }
    

    先初始化0,1节点,真正的节点从2开始赋值,insert的时候,都需要先考虑新插入的点,先写长的式子,最后遍历输出从0节点的下一个节点开始,到1节点的前面那个节点。

    #include<iostream>
    using namespace std;
    const int N=1e5;
    struct node
    {
        int val,pre,next;
    }a[N];
    int idx;
    void init()
    {
        a[0].next=1;
        a[1].pre=0;
        idx=2;
    }
    
    //表示在第k个插入的数右侧插入一个数
    void insert(int x,int k)
    {
        a[idx].val=x;
        a[idx].pre=k;
        a[idx].next=a[k].next;
        a[a[k].next].pre=idx;
        a[k].next=idx;
        idx++;
    }
    //将第k个插入的数删除
    void del(int k)
    {
        a[a[k].next].pre=a[k].pre;
        a[a[k].pre].next=a[k].next;
    }
    
    int main()
    {
        init();
        int m,x,k;
        cin>>m;
        string s;
        while(m--)
        {
            cin>>s;
            if(s=="L")
            {
                cin>>x;
                insert(x,0);
            }
            else if(s=="R")
            {
                cin>>x;
                insert(x,a[1].pre);
            }
            else if(s=="D")
            {
                cin>>k;
                del(k+1);//k+1
            }
            else if(s=="IL")
            {
                cin>>k>>x;
                insert(x,a[k+1].pre);
            }
            else
            {
                cin>>k>>x;
                insert(x,k+1);
            }
        }
        for(int i=a[0].next;i!=1;i=a[i].next)
        {
            cout<<a[i].val<<" ";
        }
        cout<<endl;
    }
    

    这样单链表和双链表都可以通过insert和del操作完成所有的基本操作,不需要分析边界。

    相关文章

      网友评论

          本文标题:数组模拟单链表,双链表

          本文链接:https://www.haomeiwen.com/subject/dbpgzqtx.html