来自https://blog.csdn.net/h294455907/article/details/80223345
这篇博客,做了一点小改动,用一个cpp实现的

#include<iostream>
using namespace std; class ListNode {
public :
int data;
ListNode *next;
}; class List {
public:
List();
~List();
void CreateList();
void Insert(int data,int index,bool flag = true);
void Delete(int index);
void printList();
void getData(int index);
int getLength();
private:
ListNode *head;
}; List::List() {
head = new ListNode();
head->next = NULL;
cout<<"创建对象成功"<<endl;
} List::~List() {
ListNode *p = head, *s;
while (p->next != NULL) {
s = p->next;
p = s->next;
delete s;
}
delete p;
delete head;
} int List::getLength() {
int len = 0;
ListNode *p = head;
while(p->next != NULL) {
len++;
p = p->next;
}
return len;
} void List::CreateList() {
int num,data;
cout<<"请输入数据个数";
cin>>num;
cout<<endl;
cout<<"请输入数据";
cout<<endl;
for(int i = 0;i<num;i++) {
cin>>data;
Insert(data,getLength()+2,false);
}
cout<<"List 创建完成"<<endl;
} void List::Insert(int data,int index,bool flag) {
ListNode *p = head, *s;
if(index<=0) {
cout<<"数据长度必须大于0";
return ;
}
if(getLength()+1<index) {
while (p->next != NULL)
{
p = p->next;
}
s = (ListNode*)new ListNode[1];
s->data = data;
s->next = NULL;
p->next = s;
if(flag!=false) {
cout<<"链表长度为"<<getLength()-1<<",无法插入到第"<<index<<"个位置";
cout<<"现将数据"<<data<<"插入到表尾部"<<endl;
}
}
else {
for(int i =0;i<index-1;i++) {
p = p->next;
}
s = (ListNode*)new ListNode[1];
s->data = data;
s->next = p->next;
p->next = s;
cout<<"数据"<<data<<"插入第"<<index<<"个位置成功!"<<endl;
}
} void List::Delete(int index) {
ListNode *p = head, *s;
int i =0;
if(index<=0||index>getLength()) {
cout<<"元素不在表中"<<endl;
return ;
}
while(i<index-1)
{
i++;
p = p->next;
}
s= p->next;
p->next = s->next;
cout<<"第"<<index<<"个元素删除成功!"<<endl;
delete s;
} void List::printList() {
ListNode *p = head;
cout<<"printList:"<<endl;
if(p->next==NULL) {
cout<<"空链表"<<endl;
return ;
}
p= p->next;
while(p!= NULL) {
cout<<p->data<<" ";
p=p->next;
}
cout<<endl;
} void List::getData(int index) {
ListNode *p = head;
if(index<=0||index>getLength()) {
cout<<"元素不在表中"<<endl;
return ;
}
for(int i = 0;i<index;i++) {
p = p->next;
}
cout<<"第"<<index<<"个元素为"<<p->data<<endl;
} int main() {
List list;
list.CreateList();
list.printList();
list.Insert(10,2);
list.Insert(20,10);
list.printList();
list.Delete(5);
list.printList();
list.getData(4);
cout<<"目前链表长度为"<<list.getLength()<<endl;
return 0;
}

 
 
 
 
 

c++实现单链表及常用方法实现的更多相关文章

  1. 单链表、循环链表的JS实现

    数据结构系列前言: 数据结构作为程序员的基本知识,需要我们每个人牢牢掌握.近期我也展开了对数据结构的二次学习,来弥补当年挖的坑......   当时上课的时候也就是跟着听课,没有亲自实现任何一种数据结 ...

  2. 时间复杂度分别为 O(n)和 O(1)的删除单链表结点的方法

    有一个单链表,提供了头指针和一个结点指针,设计一个函数,在 O(1)时间内删除该结点指针指向的结点. 众所周知,链表无法随机存储,只能从头到尾去遍历整个链表,遇到目标节点之后删除之,这是最常规的思路和 ...

  3. 单链表的C++实现(采用模板类)

    采用模板类实现的好处是,不用拘泥于特定的数据类型.就像活字印刷术,制定好模板,就可以批量印刷,比手抄要强多少倍! 此处不具体介绍泛型编程,还是着重叙述链表的定义和相关操作.  链表结构定义 定义单链表 ...

  4. Java实现单链表的各种操作

    Java实现单链表的各种操作 主要内容:1.单链表的基本操作 2.删除重复数据 3.找到倒数第k个元素   4.实现链表的反转   5.从尾到头输出链表 6.找到中间节点 7.检测链表是否有环 8.在 ...

  5. [LeetCode] Linked List Cycle II 单链表中的环之二

    Given a linked list, return the node where the cycle begins. If there is no cycle, return null. Foll ...

  6. c++单链表基本功能

    head_LinkNode.h /*单链表类的头文件*/#include<assert.h>#include"compare.h"typedef int status; ...

  7. C代码实现非循环单链表

    C代码实现非循环单链表, 直接上代码. # include <stdio.h> # include <stdlib.h> # include <malloc.h> ...

  8. 分离的思想结合单链表实现级联组件:CascadeView

    本文介绍自己最近做省市级联的类似的级联功能的实现思路,为了尽可能地做到职责分离跟表现与行为分离,这个功能拆分成了2个组件并用到了单链表来实现关键的级联逻辑,下一段有演示效果的gif图.虽然这是个很常见 ...

  9. 数据结构:单链表结构字符串(python版)添加了三个新功能

    #!/urs/bin/env python # -*- coding:utf-8 -*- #异常类 class stringTypeError(TypeError): pass #节点类 class ...

  10. 数据结构:单链表结构字符串(python版)改进

    此篇文章的replace实现了字符串类的多次匹配,但依然有些不足. 因为python字符串对象为不变对象,所以replace方法并不修改原先的字符串,而是返回修改后的字符串. 而此字符串对象时用单链表 ...

随机推荐

  1. JavaScript&TypeScript学习总结

    目录 一.JavaScript学习总结 1.什么是JavaScript 2.变量 3.变量命名 4.操作符 5.遍历语句 6.函数 7.对象 8.数组 二.TypeScript学习总结 1.什么是Ty ...

  2. andriod app更新

    对于安卓用户来说,手机应用市场说满天飞可是一点都不夸张,比如小米,魅族,百度,360,机锋,应用宝等等,当我们想上线一款新版本APP时,先不说渠道打包的麻烦,单纯指上传APP到各大应用市场的工作量就已 ...

  3. fsck.fat 检查修复(MS-DOS)fat类型文件系统

    使用方式 fsck.fat [option] DEVICE 例如 fsck.fat -aw /dev/usba0 fsck.fat 检查fat文件系统的一致性,并选择性的尝试修复他们. 如下文件系统问 ...

  4. docker 安装portainer容器后,启动/Portainer 安装MySQL并开启远程访问

    启动命令: docker run -d -p 9000:9000 --restart=always -v /var/run/docker.sock:/var/run/docker.sock --nam ...

  5. docker compose设置不同容器间通信

    docker compose新启动了一个容器,这个时候怎么去连接到其他容器呢,去容器里面ping发现不通.一般来说是因为和其他容器没有在一个网络环境里面.首先用命令查看一下当前存在哪些网络环境. 使用 ...

  6. qt 单元测试遇到的问题

    升级了qt creator到新版本.使用 google 单元测试,发现一个单元测试显示不对了. 测试结果输出:FATAL, 项目"t_ps"的测试未产生任何预期输出 比较了几个测试 ...

  7. 大道至简读后感以及JAVA伪代码

    <大道至简>这本书引用<愚公移山>一文,生动完美的诠释了编程的整个过程.在两千年前的寓言中,愚公集项目组织者.团队经理.编程人员.技术分析师等众多角色于一身.首先是原始需求的产 ...

  8. Linux系统修改静态ip

    查看所有网卡 ip信息 ipconfig 修改网卡文件 vim /etc/sysconfig/network-scripts/ifcfg-eno1(网卡名) 新增语句 IPADDR=192.168.1 ...

  9. C# List 分页代码

    List<int> testList = new List<int>();for (int i = 1; i <= 23; i++){ testList.Add(i);} ...

  10. Chrome 中的 JavaScript 断点设置和调试技巧--转自hanguokai.com

    你是怎么调试 JavaScript 程序的?最原始的方法是用 alert() 在页面上打印内容,稍微改进一点的方法是用 console.log() 在 JavaScript 控制台上输出内容.嗯~,用 ...