1.单链表
单链表的结点类型node定义:

typedef struct linknode
{
int data;
struct linknode *node;
}node;

<1>.建立单链表

void CreateSingleLink()
{
node *head, *p, *s;
int tempValue;
bool bCycle = true; //bCycle循环控制变量 head = (node *)malloc(sizeof(node)); //建立头结点
p = head; while (bCycle)
{
scanf("%d", &tempValue);
if ( != tempValue) //以0标志结束
{
s = (node *)malloc(sizeof(node)); //建立下一个结点
s->data = tempValue;
p->next = s; //把新结点连接到前面建立的链表中
p = s;
}
else
{
bCycle = false;
} } p->next = NULL; //如果是循环链表,则改为p->next = head;
p = head;
head = head->next;
free(p); //删除头结点
}

<2>.单链表查找结点

bool FindNode(node *head, int iValue)
{
bool bFind = false;
node *p;
//if 普通链表
p = head;
//else 循环列表
//if (head->data == iValue)
//{
// bFind = true;
// return bFind;
//}
//p = head->next; while (p!=NULL && p->data!=iValue)
{
p = p->next;
} if (p != NULL)
{
bFind = true;
} return bFind;
}

<3>.单链表长度
//普通链表

int LengthLink(node *head)
{
int iLength = ;
node *p;
p = head; while (p != NULL)
{
p = p->next;
iLength++;
} return iLength;
}

//循环链接

int LengthLink(node *head)
{
int iLength = ;
node *p; if (head == NULL) //空链表
{
return iLength;
} p = head->next;
iLength = ;
while (p != NULL)
{
p = p->next;
iLength++;
} return iLength;
}

<4>.单链表插入结点

bool InsertNode(node *head, int i, int iValue)
{
node *s, *p;
int j;
bool bInsert = false; s = (node *)malloc(sizeof(node)); //建立待插入结点
s->data = iValue; if (i == )
{
//表头插入结点
s->next = head;
head = s;
bInsert = true;
return bInsert;
} p = head;
j = ;
while (p!=NULL && j<i)
{
j++;
p = p->next;
} if (p != NULL)
{
//查找成功,将s插入到其后
s->next = p->next;
p->next = s;
bInsert = true;
} return bInsert;
}

<5>.单列表删除结点

bool DeleteNode(node *head, int iValue)
{
node *p, *q;
bool bDelete = false; if (head == NULL)
{
//链表为空,下溢处理
return bDelete;
} if (head->data == iValue)
{
//表头为删除结点
p =head;
head = head->next;
free(p);
bDelete = true;
return bDelete;
} q = head;
p = head->next; //从第二个结点开始查找值为iValue的结点
while (p!=NULL && p->data!=iValue)
{
if (p->data != iValue)
{
q = p;
p = p->next;
}
} if (p != NULL)
{
//找到结点,作删除处理
q->next = p->next;
free(p);
bDelete = true;
} return bDelete;
}

2.双链表
双链表结点类型定义

typedef struct linknode
{
int data;
struct linknode *left, *right;
}dnode;

<1>.创建双链表

void CreateDoubleLink()
{
dnode *head, *p, *s;
int iValue;
bool bCycle = true; //bCycle控制循环变量 head = (dnode *)malloc(sizeof(dnode));
p = head;
while (bCycle)
{
scanf("%d", &iValue);
if (iValue != ) //0作为标志结束
{
s = (dnode *)malloc(sizeof(dnode)); //建立下一个结点
s->data = iValue;
p->right = s;
s->left = p;
p = s;
}
else
{
bCycle = false;
}
} head = head->right; //删除头结点
head->left = NULL; //如果是循环双链表,则head->left = p;
p->right = NULL; //如果是循环双链表,则p->right = head;
}

<2>.查找结点
//普通双链表

bool FindNode(dnode *head, int iValue)
{
bool bFind = false;
dnode *p;
p = head; while (p!=NULL && p->data!=iValue)
{
p = p->right;
} if (p != NULL)
{
bFind = true;//找到结点
} return bFind;
}

//循环双链表

bool FindNode(dnode *head, int iValue)
{
bool bFind = false; if (head->data == iValue)
{
bFind = true;
return bFind;
} dnode *p;
p = head->right;
while (p->data!=iValue && p!=head)
{
p = p->right;
} if (p != head)
{
bFind = true; //找到结点
} return bFind;
}

<3>.双链表插入结点

bool InsertNode(dnode *head, int i, int iValue)
{
dnode *p, *s;
bool bInsert = false; s = (dnode *)malloc(sizeof(dnode)); //创建待插入结点;
s->data = iValue; if (i == )
{
//表头插入结点
s->right = head;
head->left = s;
head = s;
head->left = NULL;
bInsert = true;
return bInsert;
} int j = ;
p = head;
while (p!=NULL && j<i)
{
j++;
p = p->right;
} if (p != NULL)
{
//查找成功,把s插到p之后
if (p->right == NULL) //p为最后一个结点
{
p->right = s;
s->right = NULL;
s->left = p;
}
else
{
s->right = p->right;
p->right->left = s;
p->right = s;
s->left = p;
}
bInsert = true;
} return bInsert;
}

<4>.双链表删除结点

bool DeleteNode(dnode *head, int iValue)
{
bool bDelete = false; if (head == NULL)
{
//链表为空,下溢处理
return bDelete;
} dnode *p;
if (head->data == iValue) //表头为删除结点
{
p = head;
head = head->right;
head->left = NULL;
free(p);
bDelete = true;
return bDelete;
} p = head->right;
while (p!=NULL && p->data!=iValue)
{
if (p->data != iValue)
{
p = p->right;
}
} if (p != NULL)
{
if (p->right = NULL) //最后一个结点
{
p->left->right = NULL;
free(p);
}
else
{
p->left->right = p->right;
p->right->left = p->left;
free(p);
}
bDelete = true;
} return bDelete;
}

C/C++ 知识点---链表操作的更多相关文章

  1. c语言实现--带头结点单链表操作

    可能是顺序表研究的细致了一点,单链表操作一下子就实现了.这里先实现带头结点的单链表操作. 大概有以下知识点. 1;结点:结点就是单链表中研究的数据元素,结点中存储数据的部分称为数据域,存储直接后继地址 ...

  2. JAVA 链表操作:循环链表

    主要分析示例: 一.循环链表简述 二.单链表循环链表 三.双链表循环链表 一.循环链表简述 循环链表即链表形成了一个循环的结构,尾节点不再指向NULL,而是指向头节点HEAD,此时判定链表的结束是尾节 ...

  3. 单链表操作B 分类: 链表 2015-06-07 12:42 15人阅读 评论(0) 收藏

    数据结构上机测试2-2:单链表操作B TimeLimit: 1000ms Memory limit: 65536K 题目描述 按照数据输入的相反顺序(逆位序)建立一个单链表,并将单链表中重复的元素删除 ...

  4. YTU 2620: B 链表操作

    2620: B 链表操作 时间限制: 1 Sec  内存限制: 128 MB 提交: 418  解决: 261 题目描述 (1)编写一个函数createlink,用来建立一个动态链表(链表中的节点个数 ...

  5. C# 链表操作

    关于链表操作,在C#当中微软已经提供了一个LinkedList<T>的数据结构,通过这个类提供的一系列方法就能够实现链表操作. 这里我提供一段代码,这是在论坛里面有人提问时给出的代码,它实 ...

  6. C语言,单链表操作(增删改查)(version 0.1)

    这天要面试,提前把链表操作重新写了一遍.备份一下,以备不时之需. 希望有人能看到这篇代码,并指正. // File Name : list.h #include "stdafx.h" ...

  7. C语言链表操作模板(添加,删除,遍历,排序)

    C语言链表操作模板,摘自郝斌的C语言视频教程,简单的修改成了纯C格式.当年照着视频学习的时候记录下来的,在使用的时候直接拿来修改修改修改能节约不少时间的. /********************* ...

  8. ZT C语言链表操作(新增单向链表的逆序建立)

    这个不好懂,不如看 转贴:C语言链表基本操作http://www.cnblogs.com/jeanschen/p/3542668.html ZT 链表逆序http://www.cnblogs.com/ ...

  9. C#的链表操作[数据结构-线性表]

    链式存储结构图解: 上图中,a1,是数据,紧跟着后面的d1是下一个节点的地址值.也就是一个节点的最后存储的是下一个节点的地址值,最后一个节点的存储的下一个地址值是null,代表链表结束. 1,定义链表 ...

随机推荐

  1. Django+MySQL开发项目:内容管理系统cms(一)

    Baker-Miller Pink被科学方法证实可以平静情绪并且抑制食欲的颜色,具有amazing的效果.基百里面说实验结果表明该颜色具有: "a marked effect on lowe ...

  2. IBM Security AppScan Standard 用外部设备录制脚本(手机端应用、app、微信等)进行安全测试

    一.打开AppScan,选择外部设备/客户机,点击下一步 二.记录代理设置,可以手动输入需要的端口号,也可以自动选择,记住端口号以及PC电脑的ip地址,手机端如何设置对应的端口跟ip可以参考 Jmet ...

  3. Javascript之学习笔记每日更新

    1.输出文本 document.write(Date());输出当前时间 2.使用Jacascript改变HTML元素 //定义一个p标签,此p标签带有id元素 <p id="demo ...

  4. Linux 压缩 与解压命令

    tar命令 解包:tar zxvf FileName.tar 打包:tar czvf FileName.tar DirName gz命令 解压1:gunzip FileName.gz 解压2:gzip ...

  5. 代码规范--捡拾(SQL语句)

    最近在看阿里的JAVA开发手册,话不多说进入正题. 1.[强制]不使用count(列名)或者是count(常量)代替count(*) 因为count(*)会统计NULL值,前面的两个不会 2.[强制] ...

  6. 关于MySQL用户会话及连接线程

    0.概念理解:用户会话和连接线程是什么关系? 用户会话和用户连接线程是一一对应的关系,一个会话就一个用户连接线程. 问题描述: 如果系统因为执行了一个非常大的dml或者ddl操作导致系统hang住,我 ...

  7. 【干货】Chrome插件(扩展)开发全攻略(不点进来看看你肯定后悔)

    写在前面 我花了将近一个多月的时间断断续续写下这篇博文,并精心写下完整demo,写博客的辛苦大家懂的,所以转载务必保留出处.本文所有涉及到的大部分代码均在这个demo里面:https://github ...

  8. 第一章:selenium + java 环境安装

    1. 首先安装的是 jdk ,推荐安装的是   JDK 版本是 1.7 2.  安装 JDK 步骤: 第一步: 第二步: 第三步: 配置 JDK 环境变量,点击 我的电脑-右键-高级-环境变量. 第五 ...

  9. CJOJ 1308 【HNOI 2002 】营业额统计 / CodeVS 1296 营业额统计(STL,二分)

    CJOJ 1308 [HNOI 2002 ]营业额统计 / CodeVS 1296 营业额统计(STL,二分) Description Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一 ...

  10. 增强for循环赋值

    增强for循环赋值 代码如下: double[] testList01 = new double[5]; java.util.Scanner sc = new java.util.Scanner(Sy ...