#if 1

#include <iostream>
#include <stdlib.h>
#include <time.h>
#include <fstream>
#include <string> using namespace std; //类
class List
{
public:
//构造器初始化,生成头节点
List()
{
head = new Node;
head->next=NULL;
} //成员函数
void createList();
void insertList(int data);
void travelList();
void input();
int addNode();
void deleteData(int addNum);
void ifClear();
void clearList();
private:
//数据成员
struct Node
{
int data; //数据域
struct Node * next; //指针域 } * head;//头指针 int num;//链表元素个数
}; //头插法生成节点
void List::insertList(int data)
{
Node * cur=new Node; //插入数据
cur->data=data; //插入节点
cur->next =head->next;
head->next=cur;
} //调用insertList输入数据,生成链表
void List::input()
{
cout<<"请输入链表数量长度:";
cin >>num;
srand(time(NULL));
for(int i=0;i<num;i++)
{
insertList(rand()%100);
}
} //任意位置插入节点
int List::addNode()
{
int d,idx; cout<<"请输入你要插入的节点数据:";
cin >>d;
cout<<"请输入你要插入的节点位置: ";
cin >>idx; Node *tp=NULL;
Node *link=head; //寻找插入位置
if(idx<1||idx>num+1)
cout<<"操作非法"<<endl;
else
{
for(int i=0;i<idx;i++)
{
tp=link;
link=link->next;
} Node *cur=new Node;
tp->next=cur;
cur->data=d;
cur->next=link;
travelList();
return ++num;
}
} //遍历链表并将数据存入文件
void List::travelList()
{
ofstream mycout("D:/text.txt");
Node *temp = head->next; //防止头指针地址改变
while(temp != NULL)
{
cout<<temp->data<<" ";
mycout<<temp->data<<" ";
temp=temp->next;
}
mycout.close();
cout<<endl;
} //删除节点
void List::deleteData(int addNum)
{
int i,j=0;
cout<<"请问您要删除第几个数据: ";
cin >>i;
Node *tp=NULL;
Node *link=head;//link为删除节点后面的一个节点,temp为删除节点 if(addNum<i||i<0)
cout<<"操作非法!!"<<endl;
else
{
while(link->next)
{
tp=link->next; //第一个节点
j++;
if(i==j) //找的删除的节点
{
link->next=tp->next;
delete tp;
break;
}
link=link->next;
}
travelList();
} } //清空链表
void List::clearList()
{
Node *tp = NULL;
Node *ph=head->next; while(head->next)
{
tp=ph;
ph=ph->next;
delete tp;
head->next=ph;
} travelList();
cout<<endl;
} //询问是否清空
void List::ifClear()
{
string i; if(!head->next)
{
cout<<"链表已清空!!!"<<endl;
} else
{
cout<<"是否清空链表(是/否):";
cin>>i; if(i=="是")
{
clearList();
cout<<"链表清空完成!!!"<<endl;
}
else
cout<<"链表未清空!!!"<<endl;
}
} void main()
{
//初始化,生成头节点
List list; //输入链表长度
list.input(); //遍历链表,并存入文件
list.travelList(); //添加节点并返回总结点数
int addNum=list.addNode(); //删除节点
list.deleteData(addNum); //是否清空链表
list.ifClear(); system("pause"); }
#endif

  

总结:汉字输入需要用string,在头文件string中;字符串比较可以直接用比较运算符;

c++利用类进行单链表的插入,删除,清空操作的更多相关文章

  1. 单链表的插入删除操作(c++实现)

    下列代码实现的是单链表的按序插入.链表元素的删除.链表的输出 // mylink.h 代码 #ifndef MYLINK_H #define MYLINK_H #include<iostream ...

  2. 面试之路(10)-BAT面试之java实现单链表的插入和删除

    链表的结构: 链表在空间是不连续的,包括: 数据域(用于存储数据) 指针域(用于存储下一个node的指针) 单项链表的代码实现: 节点类 构造函数 数据域的get,set方法 指针域的get,set方 ...

  3. C语言实现单链表节点的删除(带头结点)

    我在之前一篇博客<C语言实现单链表节点的删除(不带头结点)>中具体实现了怎样在一个不带头结点的单链表的删除一个节点,在这一篇博客中我改成了带头结点的单链表.代码演示样例上传至 https: ...

  4. 数据结构与算法之PHP实现链表类(单链表/双链表/循环链表)

    链表是由一组节点组成的集合.每个节点都使用一个对象的引用指向它的后继.指向另一个节点的引用叫做链表. 链表分为单链表.双链表.循环链表.   一.单链表 插入:链表中插入一个节点的效率很高.向链表中插 ...

  5. 【线性表基础】顺序表和单链表的插入、删除等基本操作【Java版】

    本文表述了线性表及其基本操作的代码[Java实现] 参考书籍 :<数据结构 --Java语言描述>/刘小晶 ,杜选主编 线性表需要的基本功能有:动态地增长或收缩:对线性表的任何数据元素进行 ...

  6. 单链表创建、删除、查找、插入之C语言实现

    本文将详细的介绍C语言单链表的创建.删除.查找.插入以及输出功能 一.创建 #include<stdio.h> #include<stdlib.h> typedef int E ...

  7. 【剑指offer】单链表尾部插入一个节点

    #include <iostream> using namespace std; //链表结构体 struct ListNode { int m_Value; ListNode *next ...

  8. 单链表的插入伪算法和用C语言创建单链表,并遍历

    非循环单链表插入结点伪算法讲解 q插入p之后的伪算法:第一种表示方法:r = p->pNext; // p->pNext表示的是所指向结点的指针域,指针域又是指向下一个结点的地址p-> ...

  9. Linux C++ 单链表添加,删除,输出,逆序操作

    /*单链表操作*/#include <iostream>using namespace std; class Node{ public: Node(){ next=0; } Node(in ...

随机推荐

  1. SWUST OJ(599)

    拉丁方阵 #include <iostream> #include <cstdlib> using namespace std; int main() { int n; cin ...

  2. C++标准模板库(STL)之Vector

    在C中,有很多东西需要自己实现.C++提供了标准模板库(Standard Template Libray,STL),其中封装了很多容器,不需要费力去实现它们的细节而直接调用函数来实现功能. 具体容器链 ...

  3. Python3+slowloris安装使用教程

    一.说明 今天提到slowloris,这东西看着很眼熟,应该是以前局方打算用来刷竞赛积分的工具.我总觉得DoS没什么意思,但记不得怎么用了所以还是研究一下. 二.安装 slowloris就是一个pyt ...

  4. k8s 部署rabbitmq单节点

    apiVersion: extensions/v1beta1 kind: Deployment metadata: annotations: fabric8.io/iconUrl: https://r ...

  5. AngelToken钱包——值得投资与存币的钱包

    Angeltoken有多好? Angeltoken到底值不值得我们投资? 简而言之 Angeltoken结合了:钱包+机器人,钱包+币币交易,钱包+宠物,钱包+结算代币等等. 它颠覆传统的运营和赚钱模 ...

  6. python学习------面向对象的程序设计

    一 面向对象的程序设计的由来 1940年以前:面向机器 最早的程序设计都是采用机器语言来编写的,直接使用二进制码来表示机器能够识别和执行的指令和数 据.简单来说,就是直接编写 和 的序列来代表程序语言 ...

  7. ACCESS 查询重复记录

    In (SELECT [全称] FROM [New14] As Tmp GROUP BY [全称],[账号],[银行] HAVING Count(*)>1  And [账号] = [New14] ...

  8. SharedPreference映射Java类

    package com.overlook.weagree.util; import android.app.Activity; import android.content.Context; impo ...

  9. ubuntu系统 不能访问非系统磁盘即挂载的数据盘 Unable to access "DATA"

    问题描述: ubuntu14.04 有两个硬盘,一个固态硬盘作为系统盘,一个机械硬盘作为数据盘. 打开 数据盘“DATA”时出现下面的错误: Unable to access "DATA&q ...

  10. 第4次作业 -- 基于Jenkins的持续集成

    Jenkins 配置使用心得 先在 https://jenkins.io/download/ 下载Jenkins 下载之后安装,在指定的地方找到了初始密码,安装了一些插件之后,Jenkins就可以使用 ...