C/C++ 知识点---链表操作
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++ 知识点---链表操作的更多相关文章
- c语言实现--带头结点单链表操作
可能是顺序表研究的细致了一点,单链表操作一下子就实现了.这里先实现带头结点的单链表操作. 大概有以下知识点. 1;结点:结点就是单链表中研究的数据元素,结点中存储数据的部分称为数据域,存储直接后继地址 ...
- JAVA 链表操作:循环链表
主要分析示例: 一.循环链表简述 二.单链表循环链表 三.双链表循环链表 一.循环链表简述 循环链表即链表形成了一个循环的结构,尾节点不再指向NULL,而是指向头节点HEAD,此时判定链表的结束是尾节 ...
- 单链表操作B 分类: 链表 2015-06-07 12:42 15人阅读 评论(0) 收藏
数据结构上机测试2-2:单链表操作B TimeLimit: 1000ms Memory limit: 65536K 题目描述 按照数据输入的相反顺序(逆位序)建立一个单链表,并将单链表中重复的元素删除 ...
- YTU 2620: B 链表操作
2620: B 链表操作 时间限制: 1 Sec 内存限制: 128 MB 提交: 418 解决: 261 题目描述 (1)编写一个函数createlink,用来建立一个动态链表(链表中的节点个数 ...
- C# 链表操作
关于链表操作,在C#当中微软已经提供了一个LinkedList<T>的数据结构,通过这个类提供的一系列方法就能够实现链表操作. 这里我提供一段代码,这是在论坛里面有人提问时给出的代码,它实 ...
- C语言,单链表操作(增删改查)(version 0.1)
这天要面试,提前把链表操作重新写了一遍.备份一下,以备不时之需. 希望有人能看到这篇代码,并指正. // File Name : list.h #include "stdafx.h" ...
- C语言链表操作模板(添加,删除,遍历,排序)
C语言链表操作模板,摘自郝斌的C语言视频教程,简单的修改成了纯C格式.当年照着视频学习的时候记录下来的,在使用的时候直接拿来修改修改修改能节约不少时间的. /********************* ...
- ZT C语言链表操作(新增单向链表的逆序建立)
这个不好懂,不如看 转贴:C语言链表基本操作http://www.cnblogs.com/jeanschen/p/3542668.html ZT 链表逆序http://www.cnblogs.com/ ...
- C#的链表操作[数据结构-线性表]
链式存储结构图解: 上图中,a1,是数据,紧跟着后面的d1是下一个节点的地址值.也就是一个节点的最后存储的是下一个节点的地址值,最后一个节点的存储的下一个地址值是null,代表链表结束. 1,定义链表 ...
随机推荐
- xhr.readyState的就绪状态
0:初始化,XMLHttpRequest对象还没有完成初始化 1:载入,XMLHttpRequest对象开始发送请求 2:载入完成,XMLHttpRequest对象的请求发送完成 3:解析,XMLHt ...
- 自画一张linux基础架构学习框架图
草图一张,仅供参考,学习并掌握下面这张图的技能只是个开始--
- rang enumerate
叨逼叨: 小知识点 rang enumerate # 1. 请输出1-10# 2.7: 立即生成所有数字# range(1,11) # 生成 1,23,,4,56.10# 3.x: 不会立即生成,只有 ...
- JAVA中Socket的用法模拟服务端和客户端
<看透springMvc源代码分析与实践>学习笔记 Socket分为ServerSocket和Socket两个大类 ServerSocket用于服务端,可以通过accept方法监听请求,监 ...
- Unity3D拖尾组件在Ui界面下正常显示
在项目中Canvas下UI添加拖尾效果,会发现Ui完全遮挡住了拖尾. 如果要正常显示通常需要对Canvas进行设置,Render Mode 我这里用的是-Camera模式 其次要对Material 下 ...
- Unity3D文件读取
Resources: 是作为一个Unity3D的保留文件夹出现的,也就是如果你新建的文件夹的名字叫Resources,那么里面的内容在打包时都会被无条件的打到发布包中.它的特点简单总结一下就是: 只读 ...
- 与你们分享我学习linux系统的三大妙招
一说到linux,我们就自然会想到企业服务器系统,目前市场上的网络设备都是使用linux内核操作系统,一些网络服务器也是使用linux操作系统下面的服务搭建实现的:目前操作系统这块也基本被linux占 ...
- Spring3 MVC 类型转换
1. Spring在进行类型转化都是基于java.beans.PropertyEditor接口. 2. 可以使用@InitBinder来进行对单个controller的类型进行操作,比如添加Date类 ...
- Oracle查询多行数据合并成一行数据
例如: select base_id, translate (ltrim (text1, '/'), '*/', '*,') xmmc,translate (ltrim (text2, '/'), ' ...
- NOIP模拟:切蛋糕(数学欧拉函数)
题目描述 BG 有一块细长的蛋糕,长度为 n. 有一些人要来 BG 家里吃蛋糕, BG 把蛋糕切成了若干块(整数长度),然后分给这些人. 为了公平,每个人得到的蛋糕长度和必须相等,且必须是连续的一段 ...