c/c++ 链表实现
//链表的基本用法代码实现
/************************************************************************/
/* Created: 2014-03-02
/* Author: http://weibo.com/3088919800/profile
/************************************************************************/ #include "stdio.h"
#include "stdlib.h" struct ListNode
{
int value;
ListNode * next;
}; ListNode* CreateListNode(const int& nNodeValue)
{
ListNode* pNode; pNode = (ListNode*)malloc(sizeof(ListNode));
if (!pNode)
return NULL; pNode->value = nNodeValue;
pNode->next = NULL;
return pNode;
} //we need the head node value.
ListNode * CreateList(const int& nListHeadVal)
{
ListNode * li;
li = CreateListNode(nListHeadVal);
if (!li)
return NULL;
return li;
} //free all nodes in the list
void FreeList(ListNode *li)
{
ListNode * pListNode, *pTmpNode;
pListNode = li;
while (pListNode)
{
pTmpNode = pListNode;
pListNode = pListNode->next;
free(pTmpNode);
}
li = NULL;
} ListNode* AppendNode(ListNode* pList, const int &nVal)
{
ListNode* node;
ListNode* header; node = CreateListNode(nVal); if (!node)
return pList; header = pList;
if (!header)
return node; header = pList; while(header->next)
header = header->next; header->next = node; return pList;
} //if find return the node, else return null
ListNode* Find(ListNode* pList, const int& nVal)
{
ListNode* pListNode = NULL; pListNode = pList; while (pListNode)
{
if (pListNode->value == nVal)
break;
pListNode = pListNode->next;
} return pListNode;
} //insert decreasing 增减
ListNode* Insert(ListNode* pList, const int& nVal)
{ ListNode * pNewNode = NULL;
ListNode* pIterNode = NULL; pNewNode = CreateListNode(nVal);
if (!pNewNode)
return pList; if (!pList)
return pNewNode; pIterNode = pList;
while (pIterNode->value > nVal && pIterNode->next && pIterNode->next->value > nVal)
pIterNode = pIterNode->next; //if true ,it is the first node
if (pIterNode->value <= nVal)
{
pNewNode->next = pIterNode;
return pNewNode;
} if (pIterNode->next)
pNewNode->next = pIterNode->next; pIterNode->next = pNewNode; return pList;
} //insert Ascending,递增
ListNode* Insert2(ListNode* pList, const int& nVal)
{ ListNode * pNewNode = NULL;
ListNode* pIterNode = NULL; pNewNode = CreateListNode(nVal);
if (!pNewNode)
return pList; if (!pList)
return pNewNode; pIterNode = pList; while (pIterNode->value < nVal && pIterNode->next && pIterNode->next->value < nVal)
pIterNode= pIterNode->next; //if true ,it is the first node
if (pIterNode->value > nVal)
{
pNewNode->next = pIterNode;
return pNewNode;
} // insert the node.
if (pIterNode->next)
pNewNode->next = pIterNode->next;
pIterNode->next = pNewNode;
return pList;
} void PrintList(ListNode* list)
{
ListNode* pIterNode; pIterNode = list;
while (pIterNode)
{
printf("%d ", pIterNode->value);
pIterNode = pIterNode->next;
}
}
//链表倒置
ListNode* InvertList(ListNode* list)
{
ListNode *pIterNode, *pNewHead, *pTmpNode; pTmpNode = list;
if (!pTmpNode || !(pTmpNode->next))
return list; pNewHead = list;
pIterNode = list; while(pIterNode->next)
{
pTmpNode = pIterNode->next->next;
pIterNode->next->next = pNewHead;
pNewHead = pIterNode->next;
pIterNode->next = pTmpNode;
} return pNewHead;
} int main(int argc, char* argv[])
{
ListNode* list = CreateList(); ListNode* pNode;
if (!list)
{
printf("create list error!");
exit(-);
} int i = ; for (int i = ; i< ; i++)
{
list = Insert2(list, i);
} printf("\nAfter insert list: \n");
PrintList(list); list = InvertList(list);
printf("\nAfter invert the list\n");
PrintList(list); //test find .
pNode = Find(list, );
if (pNode)
{
printf("\nfind it:%d\n", pNode->value);
}
else
{
printf("\nnot find it:%d\n", );
} //free all the list node
FreeList(list); getchar();
return ;
}
c/c++ 链表实现的更多相关文章
- Redis链表实现
链表在 Redis 中的应用非常广泛, 比如列表键的底层实现之一就是链表: 当一个列表键包含了数量比较多的元素, 又或者列表中包含的元素都是比较长的字符串时, Redis 就会使用链表作为列表键的底层 ...
- [数据结构]——链表(list)、队列(queue)和栈(stack)
在前面几篇博文中曾经提到链表(list).队列(queue)和(stack),为了更加系统化,这里统一介绍着三种数据结构及相应实现. 1)链表 首先回想一下基本的数据类型,当需要存储多个相同类型的数据 ...
- 排序算法----基数排序(RadixSort(L))单链表智能版本
转载http://blog.csdn.net/Shayabean_/article/details/44885917博客 先说说基数排序的思想: 基数排序是非比较型的排序算法,其原理是将整数按位数切割 ...
- 防御性编程习惯:求出链表中倒数第 m 个结点的值及其思想的总结
防御性编程习惯 程序员在编写代码的时候,预料有可能出现问题的地方或者点,然后为这些隐患提前制定预防方案或者措施,比如数据库发生异常之后的回滚,打开某些资源之前,判断图片是否存在,网络断开之后的重连次数 ...
- 时间复杂度分别为 O(n)和 O(1)的删除单链表结点的方法
有一个单链表,提供了头指针和一个结点指针,设计一个函数,在 O(1)时间内删除该结点指针指向的结点. 众所周知,链表无法随机存储,只能从头到尾去遍历整个链表,遇到目标节点之后删除之,这是最常规的思路和 ...
- C语言之链表list
#include <stdio.h> #include <stdlib.h> #include <stdbool.h> #include <string.h& ...
- 单链表的C++实现(采用模板类)
采用模板类实现的好处是,不用拘泥于特定的数据类型.就像活字印刷术,制定好模板,就可以批量印刷,比手抄要强多少倍! 此处不具体介绍泛型编程,还是着重叙述链表的定义和相关操作. 链表结构定义 定义单链表 ...
- 学习javascript数据结构(二)——链表
前言 人生总是直向前行走,从不留下什么. 原文地址:学习javascript数据结构(二)--链表 博主博客地址:Damonare的个人博客 正文 链表简介 上一篇博客-学习javascript数据结 ...
- 用JavaScript来实现链表LinkedList
本文版权归博客园和作者本人共同所有,转载和爬虫请注明原文地址. 写在前面 好多做web开发的朋友,在学习数据结构和算法时可能比较讨厌C和C++,上学的时候写过的也忘得差不多了,更别提没写过的了.但幸运 ...
- 数据结构:队列 链表,顺序表和循环顺序表实现(python版)
链表实现队列: 尾部 添加数据,效率为0(1) 头部 元素的删除和查看,效率也为0(1) 顺序表实现队列: 头部 添加数据,效率为0(n) 尾部 元素的删除和查看,效率也为0(1) 循环顺序表实现队列 ...
随机推荐
- sql语言积累
Persons 表: Id LastName FirstName Address City 1 Adams John Oxford Street London 2 Bush George Fifth ...
- 什么情况下JVM会立即对类进行初始化
虚拟机规范严格规定了有且只有5种情况必须立即对类进行“初始化”(加载.验证.准备等阶段在此之前开始). 遇到new.getstatic.putstatic.invokestatic等4条字节码指令时. ...
- JavaScript分支结构Ⅱ—switch-case
㈠switch-case 使用场合 优先用于等值判断的条件中 ㈡switch-case 语句执行逻辑 switch case语句是一种特殊的分支结构,可以根据一个表达式的不同取值,从不同的程序入口 ...
- jquery die()方法 语法
jquery die()方法 语法 作用:die() 方法移除所有通过 live() 方法向指定元素添加的一个或多个事件处理程序.直线电机参数 语法:$(selector).die(event,fun ...
- linux 免密码 使用sudo 直接使用root权限执行命令
1.切换到root用户下,怎么切换就不用说了吧,不会的自己百度去. 2.添加sudo文件的写权限,命令是: chmod u+w /etc/sudoers 3.编辑sudoers文件 vi /etc/s ...
- List集合的三个实现类比较
1. ArrayList 底层数据结构是数组,查询快,增删慢 线程不安全,效率高 2. Vector 底层数据结构是数组,查询快,增删慢 线程安全,效率低 3. LinkedList 底层数据结构是链 ...
- 一组相关联的问题:“sudo: unable to resolve host ###: Connection timed out”、软件启动速度超慢、IPv6无法使用
造冰箱的大熊猫@cnblogs 2018/9/15 近日陆续发现计算机出现几个问题,最终发现这些问题实际上是由同一个原因导致的 问题1:无法使用IPv6 问题2:无论是启动Emacs GUI还是在命令 ...
- 文献引用 .bib文件里有公式符号
问题: 有时候文献标题带有特殊公式符号,进行BibTex编译时,会识别不出来公式符号. 例如: .bib文件里的文献: @article{XIE201892, title = "ℋ∞ con ...
- 前端学习之一_html学习
html元素分类 内连元素:出现在行内的元素 <img>,<q>,<a> 块元素:前后自动插入换行的元素 <h1> ...
- lyf基础作业
include <stdio.h> include <stdlib.h> int main (void) { FILE * fp; int a[10]; int max=0; ...