C语言链表操作模板(添加,删除,遍历,排序)
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语言链表操作模板(添加,删除,遍历,排序)的更多相关文章
- ZT C语言链表操作(新增单向链表的逆序建立)
这个不好懂,不如看 转贴:C语言链表基本操作http://www.cnblogs.com/jeanschen/p/3542668.html ZT 链表逆序http://www.cnblogs.com/ ...
- 数据结构之 线性表---单链表操作A (删除链表中的指定元素)
数据结构上机测试2-1:单链表操作A Time Limit: 1000MS Memory limit: 4096K 题目描述 输入n个整数,先按照数据输入的顺序建立一个带头结点的单链表,再输入一个数据 ...
- C语言--链表基础模板
1.建立结构体 struct ST { int num;///学号 int score;///成绩 struct ST*next; };///结构体 2.空链表的创建 struct ST creatN ...
- C 语言链表操作例程 (待完善)
#include<stdio.h>#include<malloc.h>#include<conio.h>#include<stdlib.h>#inclu ...
- js对table操作(添加删除交换上下TR)
<table width="100%" border="0" cellpadding="2" cellspacing="1& ...
- C语言链表中数组实现数据选择排序,升序、降序功能主要难点
链表排序讲解: head指针指向链表的头结点,是找到整个链表的唯一依据,如果head指针丢失,整个链表就找不到了. head存储的是第一个节点的地址,head->next存储的是第二个节点的地址 ...
- Python实现单链表数据的添加、删除、插入操作
Python实现单链表数据的添加.删除.插入操作 链表的定义: 链表(linked list)是由一组被称为结点的数据元素组成的数据结构,每个结点都包含结点本身的信息和指向下一个结点的地址.由于每个结 ...
- 玩转C语言链表-链表各类操作详解
链表概述 链表是一种常见的重要的数据结构.它是动态地进行存储分配的一种结构.它可以根据需要开辟内存单元.链表有一个"头指针"变量,以head表示,它存放一个地址.该地址指向一个元素 ...
- C语言链表全操作(增,删,改,查,逆序,递增排序,递减排序,链式队列,链式栈)
一,数据结构——链表全操作: 链表形式: 其中,每个节点(Node)是一个结构体,这个结构体包含数据域,指针域,数据域用来存放数据,指针域则用来指向下一个节点: 特别说明:对于单链表,每个节点(Nod ...
随机推荐
- android键盘锁定问题
android经常使用KeyguardLock解锁.但需要使用后打电话reenableKeyguard()锁定被解除.否则,会导致其他进程无法锁定屏幕,使用相同的WakeLock唤醒屏幕后还需要使用r ...
- mapxtreme C# 完美车辆动态轨迹展示
演示程序请在 http://pan.baidu.com/s/1jG9gKMM#dir/path=%2F%E4%BA%A7%E5%93%81%2FDemos 找 Trajectory.rar 轨迹回放功 ...
- TP-Link WR842N VPN错误619 不能建立到远程计算机的连接
一直在用Tenacy这个VPN,不限时间不限流量的,可是近期发现链接VPN总是失败.在网上查了一下,发现居然是路由器的问题!回忆一下果然是路由器出事儿了,换这个842N之前,一直是能够链接VPN的,所 ...
- 如何定义AIDL跨进程间通信
当进程A要去调用进程B中的service时,并实现通信,我们通常都是通过AIDL来操作的 projectA: 首先在我们自己的包com.wzp.aidlservice中创建一个RemoteServic ...
- DDD领域驱动设计初探
DDD领域驱动设计初探1 前言:又有差不多半个月没写点什么了,感觉这样很对不起自己似的.今天看到一篇博文里面写道:越是忙人越有时间写博客.呵呵,似乎有点道理,博主为了证明自己也是忙人,这不就来学习下D ...
- POJ 1026 Cipher(更换)
Cipher Time Limit: 1000MS Memory Li ...
- 5、VS2010+ASP.NET MVC4+EF4+JqueryEasyUI+Oracle该项目的开发——使用datagrid做报表
来点需要:我使用的数据库访问EF框架,但是,因为使用一个动态表来的统计报告中.单独是每天产生基于数据表,它是很难使用EF加盟前.所以我包装在两组数据库存取层的框内,一个是EF,一种是传统的ADO.NE ...
- ABP展现层——动态生成WebApi
ABP展现层——动态生成WebApi 点这里进入ABP系列文章总目录 ABP(现代ASP.NET样板开发框架)系列之20.ABP展现层——动态生成WebApi ABP是“ASP.NET Boilerp ...
- Log4net 日志
Log4net 日志使用介绍 概述 Log4net 有三个主要组件:loggers,appenders 和 layouts.这三个组件一起工作使得开发者能够根据信息类型和等级(Level)记录信息,以 ...
- jdk1.7 变更
个人实遇: 1.6与1.7 :SimpleDateFormat,1.6要求yyyy必须小写,1.7兼容大小写: jdk 8 新特性: 官方pdf文档(英文版)私人下载地址:http://pan.bai ...