//链表的基本用法代码实现
/************************************************************************/
/* 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++ 链表实现的更多相关文章

  1. Redis链表实现

    链表在 Redis 中的应用非常广泛, 比如列表键的底层实现之一就是链表: 当一个列表键包含了数量比较多的元素, 又或者列表中包含的元素都是比较长的字符串时, Redis 就会使用链表作为列表键的底层 ...

  2. [数据结构]——链表(list)、队列(queue)和栈(stack)

    在前面几篇博文中曾经提到链表(list).队列(queue)和(stack),为了更加系统化,这里统一介绍着三种数据结构及相应实现. 1)链表 首先回想一下基本的数据类型,当需要存储多个相同类型的数据 ...

  3. 排序算法----基数排序(RadixSort(L))单链表智能版本

    转载http://blog.csdn.net/Shayabean_/article/details/44885917博客 先说说基数排序的思想: 基数排序是非比较型的排序算法,其原理是将整数按位数切割 ...

  4. 防御性编程习惯:求出链表中倒数第 m 个结点的值及其思想的总结

    防御性编程习惯 程序员在编写代码的时候,预料有可能出现问题的地方或者点,然后为这些隐患提前制定预防方案或者措施,比如数据库发生异常之后的回滚,打开某些资源之前,判断图片是否存在,网络断开之后的重连次数 ...

  5. 时间复杂度分别为 O(n)和 O(1)的删除单链表结点的方法

    有一个单链表,提供了头指针和一个结点指针,设计一个函数,在 O(1)时间内删除该结点指针指向的结点. 众所周知,链表无法随机存储,只能从头到尾去遍历整个链表,遇到目标节点之后删除之,这是最常规的思路和 ...

  6. C语言之链表list

    #include <stdio.h> #include <stdlib.h> #include <stdbool.h> #include <string.h& ...

  7. 单链表的C++实现(采用模板类)

    采用模板类实现的好处是,不用拘泥于特定的数据类型.就像活字印刷术,制定好模板,就可以批量印刷,比手抄要强多少倍! 此处不具体介绍泛型编程,还是着重叙述链表的定义和相关操作.  链表结构定义 定义单链表 ...

  8. 学习javascript数据结构(二)——链表

    前言 人生总是直向前行走,从不留下什么. 原文地址:学习javascript数据结构(二)--链表 博主博客地址:Damonare的个人博客 正文 链表简介 上一篇博客-学习javascript数据结 ...

  9. 用JavaScript来实现链表LinkedList

    本文版权归博客园和作者本人共同所有,转载和爬虫请注明原文地址. 写在前面 好多做web开发的朋友,在学习数据结构和算法时可能比较讨厌C和C++,上学的时候写过的也忘得差不多了,更别提没写过的了.但幸运 ...

  10. 数据结构:队列 链表,顺序表和循环顺序表实现(python版)

    链表实现队列: 尾部 添加数据,效率为0(1) 头部 元素的删除和查看,效率也为0(1) 顺序表实现队列: 头部 添加数据,效率为0(n) 尾部 元素的删除和查看,效率也为0(1) 循环顺序表实现队列 ...

随机推荐

  1. 关于jq中input的value值clone的问题

    如果想将input进行克隆,然后在后面显示出来并修改input里面的文字,这时就会发现一个问题,就是你克隆出来的value值始终是你克隆时的value,检查页面元素你就会发现,这时需要对克隆之后的in ...

  2. Python可迭代序列反转总结

    字符串反转 示例:s = "hello" 方法一:使用切片 def reversed_str(s): return s[::-1] 方法二:使用reversed # 字符串 -&g ...

  3. SVN各种错误提示产生原因及处理方法大全

    SVN各种错误提示产生原因及处理方法大全 SVN各种错误提示产生原因及处理方法大全 1. svn: Server sent unexpected return value (500 Internal ...

  4. Spring中的IOC和AOP

    一.IOC(DI) Inversion of Control 控制反转,也叫(Dependency Injection)依赖注入. 我们平常使用对象的时候,一般都是直接使用关键字类new一个对象,那这 ...

  5. CSS3 阴影与圆角边框

    ㈠css3的新特性实际应用 ⑴文本阴影效果,用代码编写的方式实现   ⑵鼠标悬停的动态效果 左侧三幅图片,上面初始状态是没有说明文本的,但把鼠标放在上面的时候,这个图片上面就出现了说明文字   ⑶分栏 ...

  6. 网页“console”输出图文信息

    http://www.monmonkey.com/javascript/jiben2.html 参考以上链接中的转义字符使用. http://www.cnblogs.com/Wayou/p/chrom ...

  7. 字符串之format整理

    format 用法 本文根据官方文档及自己理解整理,只整理出自己可以理解的部分,h因个人水平有限,难免有所错误和纰漏,欢迎批评指正. 格式{ [field_name] ["!" c ...

  8. 事件总线(EventBus)

    Vue.prototype.$EventBus = new Vue() 不建议用,尽量用vuex,eventbus过于消耗浏览器资源 傻瓜版状态管理 一般的状态传递是在同时显示的情况下,倘若是在不同时 ...

  9. Ruby的异常处理

    Ruby在处理0.1+0.2是会出现精度问题: 许多语言都有类似问题,详见网址:http://0.30000000000000004.com/ Ruby的异常处理 如果异常处理范围是整个方法体,可以省 ...

  10. leetcode-easy-dynamic-198 House Robber-NO

    mycode 思路: a:1 2 3 4 5 6 7 8 9 f(9) =max( f(7) + a9 ,f(8)) 前一步.前两步 至于前三步 f(9) = f(6)+ a9,但其实f(7)在求值的 ...