首页 > 其他分享 >[YM]模板-单链表(超详细简洁模板)

[YM]模板-单链表(超详细简洁模板)

时间:2024-08-13 16:52:02浏览次数:21  
标签:Node 单链 YM int list next link 节点 模板

概念:

链表是一种用于存储数据的数据结构,通过如链条一般的指针来连接元素。它的特点是插入与删除数据十分方便,但寻找与读取数据的表现欠佳,复杂度几乎是O(n)

但其还是有很大的重要性

是数据结构的开端

模板:

题目概述:

相信大家对于单链表的操作已经游刃有余了,我们知道,对于一个单链表的能力是否健壮,可以通过它的检错能力来判断,那么现在我们需要设计一个单链表,
来实现一下的全部功能:
功能1:使用头插法在链表中插入一行元素
功能2:使用尾插法在链表中插入一行元素
功能3:按位查找,输入查找的元素位置,输出查找到的元素,如果查找成功,则输出"查找到的元素值为: xxx",反之则输出"位置不合法!!"
功能4:按值查找,输入查找的元素值,并返回查询到的元素位置,如果查找成功,则输出"查找到的元素所在位置为: xxx",反之则输出"未找到该值!!"
功能5:按位序插入,输入插入元素的位置与元素值,如果插入成功,则输出"插入成功!",反之则输出"插入位置不合法!"
功能6:按值插入,输入目标元素的值x与插入的元素值e,并在第一次出现的x值的前面插入e值,如果插入成功,则输出"插入成功!",反之则输出"未找到x!"
功能7:第七步:按位序删除,输入删除的元素的位置,如果删除成功,则输出"删除成功!你所删除的元素为: xxx",反之则输出"删除位置不合法!"
功能8:输出当前链表的长度
功能9:输出链表中的所有元素,以空格分开

创建:

typedef struct Node{
    int data;
    Node* next;
    Node(): data(0),next(NULL){} 
    Node(int x): data(x),next(NULL){}
}*ListNode;
int len;

一个节点包括了数据和指向下一个节点的地址

包含了一个空参构造和有参构造

定义了链表长度变量len

能够快速访问到链表的长度

ListNode head = new Node();

在主函数中定义链表的头节点

这个头节点只存下一个节点的地址,不存储数据

这样的操作不容易出现错误而且容易理解

头插:

新建一个节点,使得新建节点的下一个节点指向头节点的下一个节点,然后头节点指向新建节点

//1
void HeadInsert(ListNode &link_list){
    int x;
    while(cin>>x){
        Node *p=new Node(x);
        p->next=link_list->next;
        link_list->next=p;
        len++;
        if(cin.get()=='\n')break;
    }
}

尾插:

尾插就更为简单

遍历到最后一个节点

使得最后一个节点指向新建节点即可

//2
void EndInsert(ListNode &link_list){
    int x;
    while(cin>>x){
        Node *p=link_list;
        Node *t=new Node(x);
        while(p->next!=NULL)p=p->next;
        p->next=t;
        len++;
        if(cin.get()=='\n')break;
    }
}

按位查找

实质就是遍历链表

找到第x个位置输出当前节点存储的数据

//3
void IndexFind(ListNode &link_list, int pp){
    int id=1;
    Node *p = link_list->next;  
    while(p){
        if(id==pp){
            cout<<"查找到的元素值为: "<<p->data<<"\n";
            return;
        }
        p=p->next,id++;
    }
    cout<<"位置不合法!!"<<"\n";
}

按值查找

按值查找就是按位查找反过来

找到当前节点的数据跟目标数据x一致

那么就输出当前位置

//4
void ValueFind(ListNode &link_list, int v){
    int id=1;
    Node *p = link_list->next;  
    while(p){
        if(p->data==v){
            cout<<"查找到的元素所在位置为: "<<id<<"\n";
            return;
        }
        p=p->next,id++;
    }
    cout<<"未找到该值!!"<<'\n';
}

按位插入

实质还是遍历链表

找到相应位置

新建节点

使得新建节点的下一个节点指向当前节点的下一个节点

当前节点的下一个节点指向新建节点

//5
void IndexInsert(ListNode &link_list,int index, int val){
    int i=1;
    Node *p = link_list;
    while(p->next!=NULL&&i<index)p=p->next,i++;
    if(i!=index){
        cout<<"插入位置不合法!"<<'\n';
        return;
    }
    Node *t = new Node(val);
    t->next=p->next;
    p->next=t;
    len++;
    cout<<"插入成功!"<<'\n';
}

按值插入

和上个原理是一样的

这次是比较节点里的值是否和目标值一致

//6
void ValueInsert(ListNode &link_list,int x, int e){
    Node *pf=link_list;
    Node *p=link_list->next;
    while(p!=NULL&&p->data!=x)pf=p,p=pf->next;
    if(p==NULL){
        cout<<"未找到x!"<<'\n';
        return;
    }
    Node *t=new Node(e);
    pf->next=t;
    t->next=p;
    len++;
    cout<<"插入成功!\n";
}

按位删除

遍历链表找到对应位置的节点

当然

这次要定义一个前指针,指向上一个节点

后指针指向当前节点

删除操作就是

把前指针指向的上一个节点的next指向当前节点的next

最后删除当前节点,释放空间

//7
void IndexRemove(ListNode &link_list, int index){
    int id=1;
    Node *pf = link_list;
    Node *p = link_list->next;
    while(p){
        if(id==index){
            cout<<"删除成功!你所删除的元素为: "<<p->data<<"\n";
            pf->next=p->next;
            delete p;
            len--;
            return;
        }
        pf=p,p=p->next,id++;
    }
    cout <<"删除位置不合法!"<<'\n';
}

遍历链表

从头节点开始

不断用next走向下一个节点

输出当前节点的data

//9
void show(ListNode &link_list){
    Node* p = link_list->next;
    while(p){
        cout<<p->data<<" ";
        p = p->next;
    }
    cout<<"\n";
}

完整模板

typedef struct Node{
    int data;
    Node* next;
    Node(): data(0),next(NULL){} 
    Node(int x): data(x),next(NULL){}
}*ListNode;
//8
int len;
//1
void HeadInsert(ListNode &link_list){
    int x;
    while(cin>>x){
        Node *p=new Node(x);
        p->next=link_list->next;
        link_list->next=p;
        len++;
        if(cin.get()=='\n')break;
    }
}
//2
void EndInsert(ListNode &link_list){
    int x;
    while(cin>>x){
        Node *p=link_list;
        Node *t=new Node(x);
        while(p->next!=NULL)p=p->next;
        p->next=t;
        len++;
        if(cin.get()=='\n')break;
    }
}
//3
void IndexFind(ListNode &link_list, int pp){
    int id=1;
    Node *p = link_list->next;  
    while(p){
        if(id==pp){
            cout<<"查找到的元素值为: "<<p->data<<"\n";
            return;
        }
        p=p->next,id++;
    }
    cout<<"位置不合法!!"<<"\n";
}
//4
void ValueFind(ListNode &link_list, int v){
    int id=1;
    Node *p = link_list->next;  
    while(p){
        if(p->data==v){
            cout<<"查找到的元素所在位置为: "<<id<<"\n";
            return;
        }
        p=p->next,id++;
    }
    cout<<"未找到该值!!"<<'\n';
}
//5
void IndexInsert(ListNode &link_list,int index, int val){
    int i=1;
    Node *p = link_list;
    while(p->next!=NULL&&i<index)p=p->next,i++;
    if(i!=index){
        cout<<"插入位置不合法!"<<'\n';
        return;
    }
    Node *t = new Node(val);
    t->next=p->next;
    p->next=t;
    len++;
    cout<<"插入成功!"<<'\n';
}
//6
void ValueInsert(ListNode &link_list,int x, int e){
    Node *pf=link_list;
    Node *p=link_list->next;
    while(p!=NULL&&p->data!=x)pf=p,p=pf->next;
    if(p==NULL){
        cout<<"未找到x!"<<'\n';
        return;
    }
    Node *t=new Node(e);
    pf->next=t;
    t->next=p;
    len++;
    cout<<"插入成功!\n";
}
//7
void IndexRemove(ListNode &link_list, int index){
    int id=1;
    Node *pf = link_list;
    Node *p = link_list->next;
    while(p){
        if(id==index){
            cout<<"删除成功!你所删除的元素为: "<<p->data<<"\n";
            pf->next=p->next;
            delete p;
            len--;
            return;
        }
        pf=p,p=p->next,id++;
    }
    cout <<"删除位置不合法!"<<'\n';
}
//9
void show(ListNode &link_list){
    Node* p = link_list->next;
    while(p){
        cout<<p->data<<" ";
        p = p->next;
    }
    cout<<"\n";
}
void solve(){
    ListNode head = new Node();
    int op,x,y;
    if(head==NULL)cout<<"true"<<"\n";
    while(cin>>op){
        if(!op)break;
        if(op==1)HeadInsert(head);
        if(op==2)EndInsert(head);
        if(op==3)cin>>x,IndexFind(head,x);
        if(op==4)cin>>x,ValueFind(head,x);
        if(op==5)cin>>x>>y,IndexInsert(head,x,y);
        if(op==6)cin>>x>>y,ValueInsert(head,x,y);
        if(op==7)cin>>x,IndexRemove(head,x);
        if(op==8)cout<<len<<"\n";
        if(op==9)show(head);
    }
}

标签:Node,单链,YM,int,list,next,link,节点,模板
From: https://blog.csdn.net/2302_80481841/article/details/141166868

相关文章

  • pbootcms模板自动清理runtime缓存
    打开/apps/home/controller/ExtLabelController.php文件找到  //测试扩展单个标签  privatefunctiontest()  {    $this->content=str_replace('{pboot:userip}',get_user_ip(),$this->content);  }}在它下面加入//自动会话清理脚本publicfunc......
  • Chapter 34 PyMySQL 基本操作指南
    欢迎大家订阅【Python从入门到精通】专栏,一起探索Python的无限可能!文章目录前言一、基本操作步骤二、综合案例分析前言在现代应用开发中,与数据库的高效交互是关键的一环。对于使用Python语言的开发者来说,PyMySQL是一个非常实用的工具,它提供了一个简洁且功能强......
  • dyMEAN代码分析
    这段代码的作用是生成一个cmask列表,用于指示在模型的预测过程中,哪些残基的坐标需要被生成(预测),哪些残基的坐标是固定的(不需要预测)。以下是对这行代码的详细解读:1.背景信息cmask:这是一个掩码(mask),用于指定哪些坐标需要生成(由模型预测),哪些坐标保持固定(不变)。0表示坐标是固......
  • Makefile 编译多级目录多个目标文件模板
    对于当前目录结构下的Makefile(基于图书管理系统).├──Makefile├──README.md├──bin│├──adminsys│└──usersys├──build│├──adminmain.o│├──generalcore.o│├──generalimpl.o│├──generalview.o│├──......
  • QSortFilterProxyModel和QTreeView排序功能
    1、需求,创建一个树有多层结构,同一层按照插入顺序逆序排列; ui.treeView->setHeaderHidden(true);//treewidget头标题是否显示,此处隐藏标题//ui.treeWidget->header()->setHorizontalScrollMode(QAbstractItemView::ScrollPerPixel);ui.treeView->header()->s......
  • 【C++面向对象】泛型编程(模板) 新手小白都能懂!
    目录泛型编程是什么?模板和泛型编程的关系?函数模板定义调用类模板定义调用总结/小注泛型编程是什么?顾名思义,“泛型”即“广泛的类型”,即不拘泥于一种特定类型的编程方法。在泛型编程时,我们通常使用一个或多个类型占位符来表示一种或多种类型,这些类型对于模板而言......
  • 帝国cms手机端模板怎么用
    帝国CMS手机端模板为网站提供优化后的移动端浏览体验。使用帝国CMS手机端模板非常简单,以下是分步指南:步骤1:查找并下载模板访问帝国CMS官方网站或第三方模板市场,浏览和下载您喜欢的手机端模板。步骤2:上传模板到帝国CMS登录帝国CMS后台,导航到“模板管理”>“手机端模板”......
  • 洛谷 P4556 雨天的尾巴之线段树合并模板
    洛谷P4556题解传送锚点摸鱼环节[Vani有约会]雨天的尾巴/【模板】线段树合并题目背景深绘里一直很讨厌雨天。灼热的天气穿透了前半个夏天,后来一场大雨和随之而来的洪水,浇灭了一切。虽然深绘里家乡的小村落对洪水有着顽固的抵抗力,但也倒了几座老房子,几棵老树被连根拔起,以......
  • 简单的python web项目的docker-compose.yml 示例
    一个简单的pythonweb项目,包含redis,mysql,nginx,定时业务调度等其中web启动注册了自定义命令flaskcreate-db&&flaskinit-db&&uwsgi/web/uwsgi.iniversion:'3.5'services:db:image:mysqlcontainer_name:yeping_mysqlcommand:--default-......
  • 单链表与双链表的代码实现
    单链表链表的概念链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表比数组的优势在于,它可以提供高效的重排数据的能力。这种灵活性的代价是不能快速访问表中的任意数据项,访问链表中数据项的唯一方式是沿着链表,一个......