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. 减少iPhone手机系统版本号

    要减少移动版本号,本号,或者到"威风"站点或其他能够下载到iPhone固件的站点上下载固件,然后打开iTunes,进入到 然后按着(alt),同一时候用鼠标点击(更新button) ...

  2. JavaScript之二:this

    在JavaScript中,this的指代对象是什么?最精辟的解释却只有一句话: when a function of an object was called, the object will be ...

  3. 安卓模拟器错误: Could not open

    在进行android模拟器測试的时候,出现下面错误,进度条满了之后就没反应了.图例如以下: 引起这个问题的可能原因有非常多: 原因一:由于我们採用的是绝对路径定位.也就是说在环境变量里面把路径写死了, ...

  4. Linux内核分析(三)----初识linux内存管理子系统

    原文:Linux内核分析(三)----初识linux内存管理子系统 Linux内核分析(三) 昨天我们对内核模块进行了简单的分析,今天为了让我们今后的分析没有太多障碍,我们今天先简单的分析一下linu ...

  5. OAuth和OpenID的区别(转)

    OAuth(开放授权)是一个开放标准,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源(如照片,视频,联系人列表),而无需将用户名和密码提供给第三方应用.  OAuth协议为用户资源的授权提 ...

  6. 在WIN7笔记本电脑系统的建立WIFI热点

        成功的关键是,你在运行秩序:       前置条件:右键"我的电脑"--"属性"--"设备管理器"--"网络适配器&quo ...

  7. javaScript在私有的属性和方法

    javaScript并没有什么特别的语法来代表私人.保.或公共的属性和方法,在这一点上与 java或其他语言是不同的.JavaScript大家是共同的所有对象: var myobj={ mypop:1 ...

  8. android studio 在线更新android sdk,遇到无法Fetching https://dl-ssl.google.com/...的解决方式

    近期实在受不了eclipse的"迟钝",准备入手Android studio开发环境,可是貌似不太顺利,安装成功了Android studio,在线更新Android adk的时候 ...

  9. Sicily 1299 Academy Awards (map + vector)集装箱

    链接:http://soj.me/show_problem.php?pid=1299&cid= Description Selected from 3,850 teams from 1,329 ...

  10. View中选择的数据行中的部分数据传入到Controller中

    将View中选择的数据行中的部分数据传入到Controller中   ASP.NET MVC搭建项目后台UI框架—1.后台主框架 ASP.NET MVC搭建项目后台UI框架—2.菜单特效 ASP.NE ...