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

/*********************************
*
* 代码摘自郝斌C语言视频的链表部分
* 简单修改为纯C格式
*
*/ #include <stdio.h>
#include <malloc.h>
#include <stdlib.h> typedef struct Node {
int date;
struct Node *pNext;
}NODE, *PNODE; PNODE create_list(void);
void traverse_list(PNODE pHead);
int is_empty(PNODE);
int length_list(PNODE);
void sort_list(PNODE);
int insert_list(PNODE, int, int);
int delete_list(PNODE, int, int *); int main()
{
PNODE pHead = NULL;
pHead = create_list();
traverse_list(pHead);
//is_empty(pHead);
//cout << "链表中的节点个数为:" << length_list(pHead) << endl;
//sort_list(pHead);//链表排序
//insert_list(pHead, 4, 33);
//traverse_list(pHead);//读取链表
//sort_list(pHead);//链表排序
int Val = ;
if(delete_list(pHead, , &Val)) {
printf("删除节点成功,删除的元素是: %d", Val);
}
else
printf("删除失败\n");
traverse_list(pHead);//读取链表
return ;
} PNODE create_list(void)
{
int i, len, val;
PNODE pHead = (PNODE)malloc(sizeof(NODE));
if(NULL == pHead) {
printf("头结点内存分配失败,退出程序");
exit(-);
} printf("请输入创建节点的个数:len = ");
scanf("%d", &len); PNODE pTail = pHead;
pTail->pNext = NULL; for(i=; i<len; ++i)
{
printf("请输入第%d个节点的值: ", i+);
scanf("%d", &val); PNODE pNew = (PNODE)malloc(sizeof(NODE));
if(NULL == pNew) {
printf("内存分配失败,退出程序");
system("pause");
exit(-);
}
pNew->date = val;
pTail->pNext = pNew;
pNew->pNext = NULL;
pTail = pNew;
}
return pHead;
} void traverse_list(PNODE pHead)
{
PNODE p = pHead->pNext; while(p != NULL) {
printf("%d ", p->date);
p = p->pNext;
}
printf("\n");
return;
} int is_empty(PNODE pHead) {
if(NULL == pHead->pNext) {
printf("链表为空!\n");
return ;
}
else {
printf("链表不为空!\n");
return ;
}
} int length_list(PNODE pHead) {
int len = ;
PNODE p = pHead->pNext; while(p != NULL) {
++len;
p = p->pNext;
}
return len;
} void sort_list(PNODE pHead) {
int i, j, t;
PNODE p, q;
int len = length_list(pHead); for(i=,p=pHead->pNext; i<len-; ++i, p=p->pNext) {
for(j=i+,q=p->pNext; j<len; ++j,q=q->pNext) {
if(p->date > q->date) {
t = p->date;
p->date = q->date;
q->date = t;
}
}
}
return;
} int insert_list(PNODE pHead, int pos, int val) {
int i = ;
PNODE p = pHead; while(p != NULL && i < pos-) {
p = p->pNext;
++i;
}
if(i > pos- || p == NULL)
return ; PNODE pNew = (PNODE)malloc(sizeof(NODE));
if(pNew == NULL) {
printf("动态申请内存失败\n");
exit(-);
}
pNew->date = val;
pNew->pNext = p->pNext;
p->pNext = pNew;
return ;
} int delete_list(PNODE pHead, int pos, int *pVal) {
int i = ;
PNODE p = pHead; while(p->pNext != NULL && i < pos-) {
p = p->pNext;
++i;
}
if(i > pos- || p->pNext == NULL)
return ;
PNODE q = p->pNext;
*pVal = q->date; p->pNext = p->pNext->pNext;
free(q);
q = NULL; return ;
}

C语言链表操作模板(添加,删除,遍历,排序)的更多相关文章

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

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

  2. 数据结构之 线性表---单链表操作A (删除链表中的指定元素)

    数据结构上机测试2-1:单链表操作A Time Limit: 1000MS Memory limit: 4096K 题目描述 输入n个整数,先按照数据输入的顺序建立一个带头结点的单链表,再输入一个数据 ...

  3. C语言--链表基础模板

    1.建立结构体 struct ST { int num;///学号 int score;///成绩 struct ST*next; };///结构体 2.空链表的创建 struct ST creatN ...

  4. C 语言链表操作例程 (待完善)

    #include<stdio.h>#include<malloc.h>#include<conio.h>#include<stdlib.h>#inclu ...

  5. js对table操作(添加删除交换上下TR)

    <table width="100%" border="0" cellpadding="2" cellspacing="1& ...

  6. C语言链表中数组实现数据选择排序,升序、降序功能主要难点

    链表排序讲解: head指针指向链表的头结点,是找到整个链表的唯一依据,如果head指针丢失,整个链表就找不到了. head存储的是第一个节点的地址,head->next存储的是第二个节点的地址 ...

  7. Python实现单链表数据的添加、删除、插入操作

    Python实现单链表数据的添加.删除.插入操作 链表的定义: 链表(linked list)是由一组被称为结点的数据元素组成的数据结构,每个结点都包含结点本身的信息和指向下一个结点的地址.由于每个结 ...

  8. 玩转C语言链表-链表各类操作详解

    链表概述 链表是一种常见的重要的数据结构.它是动态地进行存储分配的一种结构.它可以根据需要开辟内存单元.链表有一个"头指针"变量,以head表示,它存放一个地址.该地址指向一个元素 ...

  9. C语言链表全操作(增,删,改,查,逆序,递增排序,递减排序,链式队列,链式栈)

    一,数据结构——链表全操作: 链表形式: 其中,每个节点(Node)是一个结构体,这个结构体包含数据域,指针域,数据域用来存放数据,指针域则用来指向下一个节点: 特别说明:对于单链表,每个节点(Nod ...

随机推荐

  1. POSIX 螺纹具体解释(1-概要)

    线程是有趣的 线程类似于进程.如同进程,线程由内核按时间分片进行管理.在单处理器系统中,内核使用时间分片来模拟线程的并发运行.这样的方式和进程的同样. 而在多处理器系统中,如同多个进程.线程实际上一样 ...

  2. vim cheat sheet

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzE1Mjg5NQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...

  3. JavaScript的隐式转换

    原文:JavaScript的隐式转换 JavaScript的数据类型分为六种,分别为null,undefined,boolean,string,number,object.object是引用类型,其它 ...

  4. 把自解压的RAR压缩包解压到指定的软件安装目录

    原文 把自解压的RAR压缩包解压到指定的软件安装目录 今天千里独行同学给轻狂来信问了一个问题:如何把一个自解压的RAR压缩包解压到我们指定的软件安装目录.   其实,在NSIS中,我们可以灵活运用相关 ...

  5. Android Bitmap OutOfMemory 解决的方法

    在Android应用里,最耗费内存的就是图片资源.并且在Android系统中.读取位图Bitmap时,分给虚拟机中的图片的堆栈大小仅仅有8M.假设超出了.就会出现OutOfMemory异常 E/And ...

  6. 一Flash从入门开发者放弃了成长之路

    本文将依照入门.成长.转行三个关键词来讲述作者这些年使用Flash进行项目开发的整个历史过程. 一.入门--開始走上Flash的道路. 和Flash的机缘要从大学时代说起.2005年下半年.学校开设了 ...

  7. 向西项目管理工具Maven一片

    前言 相信仅仅要做过 Java 开发的童鞋们,对 Ant 想必都不陌生,我们往往使用 Ant 来构建项目,尤其是涉及到特别繁杂的工作量.一个 build.xml 可以完毕编译.測试.打包.部署等非常多 ...

  8. bigdata_一篇文看懂Hadoop

    本文转载:暂未找到原出处,如需署名 请联系 我们很荣幸能够见证Hadoop十年从无到有,再到称王.感动于技术的日新月异时,希望通过这篇内容深入解读Hadoop的昨天.今天和明天,憧憬下一个十年. 本文 ...

  9. 【高德地图API】从零开始学高德JS API(二)地图控件与插件——测距、圆形编辑器、鼠标工具、地图类型切换、鹰眼鱼骨

    原文:[高德地图API]从零开始学高德JS API(二)地图控件与插件——测距.圆形编辑器.鼠标工具.地图类型切换.鹰眼鱼骨 摘要:无论是控件还是插件,都是在一级API接口的基础上,进行二次开发,封装 ...

  10. ZOJ 3802 Easy 2048 Again 像缩进DP

    链接:problemId=5334">http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5334 题意:一个长度为5 ...