//链表的基本用法代码实现
/************************************************************************/
/* 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. 面试题:Dubbo中zookeeper做注册中心,如果注册中心集群全都挂掉,发布者和订阅者之间还能通信么?

    1.[提供者]在[启动]时,向注册中心zk [注册]自己提供的服务. 2.[消费者]在[启动]时,向注册中心zk [订阅]自己所需的服务.   可以的,消费者在启动时,消费者会从zk拉取注册的生产者的 ...

  2. 把自己的web项目发布到网页上

    一.首先,登录自己的bce百度云,bce.baidu.com,建立一个自己的网站 点击左边的应用引擎BAE 点击BAE基础版的部署列表,刚开始是没有的,要添加部署 其中的选项只需要写域名(应用名称会和 ...

  3. RFID-RC522射频

    与Arduino的接线方法: 米其林编程:

  4. Centos7——docker入门(笔记)

    docker 入门(笔记) 一.Docker是什么? 官方原话: Docker provides a way to run applications securely isolated in a co ...

  5. Java——静态代理、动态代理

    https://blog.csdn.net/giserstone/article/details/17199755 代理的作用:业务类只需要关注业务逻辑本身,保证了业务类的重用性 一 静态代理 特点: ...

  6. 51 Nod 线段最长重叠部分

    1091 线段的重叠  基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题 X轴上有N条线段,每条线段包括1个起点和终点.线段的重叠是这样来算的,[10 20]和[12 ...

  7. [CSP-S模拟测试]:统计(树状数组+乱搞)

    题目传送门(内部题120) 输入格式 第一行,两个正整数$n,m$. 第二行,$n$个正整数$a_1,a_2,...,a_n$,保证$1\leqslant a_i\leqslant n$,可能存在相同 ...

  8. 利用freemarker生成word,word另存为xml文件的标签解析

    http://wenku.baidu.com/link?url=YxTZWVP3ssO-e_Br3LIZVq2xOQnqaSz8gLPiRUDN8NIR_wX2-Z25OqwbVn5kXqGiOFYU ...

  9. Unit Test in SpringBoot

    此处的Unit Test in SpringBoot 包括: SpringApplication Test Service Test ControllerTest 测试项目结构如下: 代码如下: PO ...

  10. 上传本地文件到linux

    Linux 命令行上传文件 Linux服务器,硬盘坏了,更换硬盘后,重装了好像是Foreda v22的操作系统,我在/var/www/html/目录下新建了我的个人文件夹 kma,然后我在此kma文件 ...