C++ 数据结构学习二(单链表)
模板类
//LinkList.h 单链表
#ifndef LINK_LIST_HXX
#define LINK_LIST_HXX
#include <iostream>
using namespace std;
template<class T>
struct Node
{
T data;
Node * next;
};
template<class T>
class LinkList
{
public:
LinkList(); //无参构造函数,建立只有头结点的空链表
LinkList(T a[],int n); //有参构造函数,建立有n个元素的单链表
~LinkList(); //析构函数
int Length(); //求单链表长度
T Get(int i); //按位查找,在单链表中查找第i个结点的元素值
int Locate(T x); //按值查找,在单链表中查找值为x的元素序号
void Insert(int i,T x); //插入操作,在第i个位置插入元素值为x的结点
T Delete(int i); //删除操作,在单链表中删除第i个结点
void PrintList(); //遍历操作,按顺序依次输出各元素
private:
Node<T> * first; //单链表的头指针
};
template<class T>
LinkList<T>::LinkList()
{
first=new Node<T>; //生成头结点
first->next=NULL; //头结点指针置空
}
/*
template<class T>
LinkList<T>::LinkList(T a[],int n) //头插法建立单链表LinkList
{
first=new Node<T>;
first->next=NULL; //初始化一个空链表
for(int i=0;i<n;i++)
{
Node<T> *s=new Node<T>;
s->data=a[i]; //为每个元素建立一个结点
s->next=first->next;
first->next=s; //将结点s插入到头结点之后
}
}
*/
template<class T>
LinkList<T>::LinkList(T a[],int n) //尾插法建立单链表LinkList
{
first=new Node<T>;
Node<T> *r=new Node<T>;
r=first;
for(int i=0;i<n;i++)
{
Node<T> *s=new Node<T>;
s->data=a[i]; //为每个元素建立一个结点
r->next=s; //将结点s插入到终结点之后
r=s;
}
r->next=NULL; //单链表建立完毕,将终结点的指针置空
}
template<class T>
LinkList<T>::~LinkList()
{
while(first!=NULL) //释放单链表的每一个结点的存储空间
{
Node<T> *q=new Node<T>;
q=first; //暂存被释放的结点
first=first->next;//first指向被释放结点的下一个结点
delete q;
}
}
template<class T>
int LinkList<T>::Length()
{
Node<T> *p=first->next;
int count=0; //工作指针p和累加器count初始化
while(p!=NULL)
{
p=p->next;
count++;
}
return count; //注意count的初始化和返回值的关系
}
template<class T>
T LinkList<T>::Get(int i)
{
Node<T> *p=first->next;
int count=1;
while(p!=NULL&&count<i)
{
p=p->next;
count++;
}
if(p==NULL) throw "位置错误";
else return p->data;
}
template<class T>
int LinkList<T>::Locate(T x)
{
Node<T> *p=first->next;
int count=1;
while(p!=NULL)
{
if(p->data==x) return count; //查找成功,结束返回位号
p=p->next;
count++;
}
return 0; //返回0表明查找失败
}
template<class T>
void LinkList<T>::Insert(int i,T x)
{
Node<T> *p=first->next; //工作指针指向头结点
int count=1;
while(p!=NULL&&count<i-1) //查找第i-1个结点
{
p=p->next; //工作指针后移
count++;
}
if(p==NULL) throw "位置"; //没有找到第i-1个结点
else{
Node<T> *s=new Node<T>;
s->data=x;
s->next=p->next; //将结点s插到结点p之后
p->next=s;
}
}
template<class T>
T LinkList<T>::Delete(int i)
{
Node<T> *p=new Node<T>;
p=first->next;
int count=1;
while(p!=NULL&&count<i-1)
{
p=p->next;
count++;
}
if(p==NULL||p->next==NULL) throw "位置"; //结点p不存在 或者 p指向的下一个结点不存在
else{
Node<T> *q=new Node<T>;
q=p->next;
T x=p->data;
p->next=q->next; //摘链
delete q;
return x;
}
}
template<class T>
void LinkList<T>::PrintList()
{
Node<T> *p=first->next;
while(p!=NULL)
{
cout<<p->data<<endl;
p=p->next;
}
}
#endif
测试
//LinkListDemo.cpp
#include <iostream>
#include "LinkList.h"
using namespace std;
int main()
{
int a[10]={1,2,3,4,5,6,7,8,9,10};
LinkList<int> linkList(a,10);
cout<<"原始单链表数据"<<endl;
linkList.PrintList();
cout<<"数据总量"<<linkList.Length()<<endl;
linkList.Delete(5);
cout<<"删除后数据"<<endl;
linkList.PrintList();
cout<<"数据总量"<<linkList.Length()<<endl;
linkList.Insert(5,108);
cout<<"插入后数据"<<endl;
linkList.PrintList();
cout<<"数据总量"<<linkList.Length()<<endl;
cout<<"查询数据"<<linkList.Get(10)<<endl;
cout<<"查询位置"<<linkList.Locate(108);
return 0;
}
C++ 数据结构学习二(单链表)的更多相关文章
- 数据结构——Java实现单链表
一.分析 单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素.链表中的数据是以结点来表示的,每个结点由元素和指针构成.在Java中,我们可以将单链表定义成一个类,单链表的基 ...
- PHP数据结构之实现单链表
学习PHP中,学习完语法,开始尝试实现数据结构,今天实现单链表 <?php class node //节点的数据结构 { public $id; public $name; public $ne ...
- js数据结构与算法--单链表的实现与应用思考
链表是动态的数据结构,它的每个元素由一个存储元素本身的节点和一个指向下一个元素的引用(也称指针或链接)组成. 现实中,有一些链表的例子. 第一个就是寻宝的游戏.你有一条线索,这条线索是指向寻找下一条线 ...
- 自己动手实现java数据结构(二) 链表
1.链表介绍 前面我们已经介绍了向量,向量是基于数组进行数据存储的线性表.今天,要介绍的是线性表的另一种实现方式---链表. 链表和向量都是线性表,从使用者的角度上依然被视为一个线性的列表结构.但是, ...
- c++学习笔记—单链表基本操作的实现
用c++语言实现的单链表基本操作,包括单链表的创建(包括头插法和尾插法建表).结点的查找.删除.排序.打印输出.逆置.链表销毁等基本操作. IDE:vs2013 具体实现代码如下: #include ...
- 链表学习二:链表反转与查找倒数第K个
//单链表反转 ListNode* RevertList(ListNode* m_pHead){ ListNode* pCurrent = m_pHead; ListNode* pPrev=NULL; ...
- 数据结构:DHUOJ 单链表ADT模板应用算法设计:长整数加法运算(使用单链表存储计算结果)
单链表ADT模板应用算法设计:长整数加法运算(使用单链表存储计算结果) 时间限制: 1S类别: DS:线性表->线性表应用 题目描述: 输入范例: -5345646757684654765867 ...
- c++学习之单链表以及常用的操作
新学数据结构,上我写的代码. #include <iostream> #include <cstdlib> using namespace std; typedef int E ...
- C语言学习016:单链表
#include <stdio.h> //定义一个链表,链表是一种递归结构,在定义的时候必须要给结构起一个名字 typedef struct folder{ int level; char ...
随机推荐
- Eclipse上GIT插件EGIT使用
一.安装EGit插件 參考:MyEclipse8.5整合Git 二.EGit配置 配置个人信息 Window > Preferences > Team > Git > Conf ...
- ASP.NET MVC 3 配置EF自动生成模型
Tools(工具) => 扩展工具 => Nuget Tools(工具) => Nuget=>程序包管理器控制台 Nuget 程序包管理器 => Install-Pac ...
- Arcgis Runtime sdk for android 授权
要下载和安装 ArcGISRuntime SDK for Android,您需要注册开发者账户,进而便拥有了访问所有功能的权限,从而实现开发和测试目的.但是,这种情况下,应用程序中的所有地图都具有水印 ...
- 全站 HTTPS
1.HTTPS 基础 HTTPS(Secure Hypertext Transfer Protocol)安全超文本传输协议 它是一个安全通信通道,它基于HTTP开发,用于在客户计算机和服务器之间交换信 ...
- IDEA工具配置以及常用快捷键
1.修改JVM参数 (IntelliJ IDEA 10.0.1包含以上版本不需要设置)修改idea.exe.vmoptions配置文件调整以下内容:-Xms256m-Xmx384m-XX:MaxPer ...
- Android 模块化编程之引用本地的aar
转: http://www.stormzhang.com/android/2015/03/01/android-reference-local-aar/ 随着项目越来越多,代码的复用就变得异常重要,这 ...
- 使用file_get_content系列函数和使用curl系列函数采集图片的性能对比
由于公司的一个汽车网站的后台的汽车内容都是主要是来自与汽车之家的,编辑的同事们必须天天手动去对着汽车之家来添加汽车,实在是太蛋疼了.于是乎,为了改变这种状况,作为一个开发码农,我的任务就来了...那就 ...
- linux判断日期是否合法
#include <time.h> #include <stdio.h> typedef enum { , } bool; bool check_date(int year, ...
- SQL Server 数据库状态选项
选项 1. single_user(单用户),multi_user(多用户),restricted_user(受限用户); 描述数据库的用户访问属性,它们互斥,设置其中任何一个选项就会取消对其它选项的 ...
- 如何使用for循环连续的实例化多个对象!
Test类import java.util.ArrayList; import java.util.List; import java.util.Scanner; public class Test ...