C语言之链表
这两天在复习C语言的知识,为了给下个阶段学习OC做准备,以下的代码的编译运行环境是Xcode5.0版本,写篇博文把昨天复习的C语言有关链表的知识给大家分享一下,以下是小菜自己总结的内容,代码也是按照自己的思路所编写的,有不足之处还请大牛们批评指教。
确切的说链表属于数据结构中线性表中的内容,在链表中存储的内容是按线性排列的,就像是一条线把所要存的数据串起来,可以把链表类比成一串珠子,数据就是一个个的珠子,数据间的next指针就相当于穿珠子的线。
链表操作的时间复杂度: 往链表中插入数据的时间复杂度为O(1)。
想真正的理解链表及在C语言中的表示方法的前提是理解C语言中的指针和结构体,闲话少说,进代码才是关键,代码中基本上都有注释
1.用结构体定义链表的节点
//定义链表中的节点
typedef struct node{
//存储数据
int data;
//指向下一个节点
struct node *next;
}Node;
2.定义链表的整体结构,存放链表的节点和链表中的信息
//定义链表结构
typedef struct {
//存放头节点
Node *head;
//记录节点的个数
int count;
}List;
3.链表的初始化,给链表分配头结点,节点个数初始化为0
/************************************************
*功能:初始化链表,分配头结点,结点个数为0
*参数:链表指针
*作者:Mr.li
*日期:14-07-23
************************************************/
void initLinkList(List *list)
{
//给头节点分配内存
list->head = malloc(sizeof(Node));
//头结点的下一个节点为空
list->head->next = NULL;
//总节点个数为0
list->count = ;
}
4.建立单项链表,这里为了简单起见,把要存入数据先存入到array中,下面我是用逆序的方法来创建链表的,是从head节点后插入数据,也可以用顺序建链表,从链表的后面插入数据
/************************************************
*功能:逆序建立链表,从头结点后插入
*参数:链表指针
*作者:Mr.li
*日期:14-07-23
************************************************/
void createLinkList(List *list)
{
//建立链表用到的数据
] = {,,,,,,,,,};
//临时节点指针用于分配节点内存
Node *p;
; i < ; i++)
{
//给新的节点分配内存
p = (Node *)malloc(sizeof(Node));
//给新节点赋值
p->data = a[i];
//把值加入到头节点后面,逆序建立链表
p->next = list->head->next;
list->head->next = p;
//链表节点个数加一
list->count++;
}
}
5.为了方便查看链表中的值,需要一个打印链表中的数据的函数
/************************************************
*功能:打印链表中的值
*参数:链表指针
*作者:Mr.li
*日期:14-07-23
************************************************/
void printList(List *list)
{
//临时节点指针变量
Node *p;
//从头开始遍历
p = list->head->next;
while (p != NULL)
{
//自定义的输出整的函数
print(p->data);
p = p->next;
}
putchar('\n');
}
6.查询元素在链表中对于的位置
/************************************************
*功能:查找链表中指定值的位置,有的返还其位置,无,返还-1
*参数:链表指针,要查找的值
*作者:Mr.li
*日期:14-07-23
************************************************/
int search(List *list, int obj)
{
//定义游标指针
Node *p;
//标记值的位置
;
p = list->head->next;
while (p != NULL)
{
local ++;
if (p->data == obj)
{
//返回值的位置
return local;
}
p = p->next;
}
//值不存在返回-1
;
}
7.删除链表中的相应的数据
/************************************************
*功能:删除链表中的值
*参数:链表指针,要删除的值
*作者:Mr.li
*日期:14-07-23
************************************************/
void delete(List *list, int obj)
{
//查询要删除的元素是否在链表中,有返还相应的位置,没有则返还-1
int flag = search(list, obj);
//判断值的合法性
)
{
printf("没有要删除的值!\n");
}
else
{
//定义两个辅助游标指针
Node *p, *q;
//给q,p赋值
q= list->head;
p = list->head->next;
//循环查找相应的值并删除
while (p != NULL)
{
if (p->data == obj)
{
q->next = p->next;
p->next = NULL;
free(p);
break;
}
q = p;
p = p->next;
}
}
}
8.往链表中插入数据
/************************************************
*功能:往指定的位置后插入相应的值
*参数:链表指针,插入的位置,插入的值
*作者:Mr.li
*日期:14-07-23
************************************************/
void insert(List *list, int local, int number)
{
;
//判断值的合法性
if(count > list->count)
{
printf("你输入的值不合法\n");
}
else
{
//定义游标指针,指向链表的头结点
Node *p = list->head;
while (count != local) {
p++;
count++;
}
//分配新的结点并给新的结点赋值
Node *q = (Node *) malloc(sizeof(Node));
q->data = number;
q->next = NULL;
//插入新的结点
q->next = p->next;
p->next = q;
}
}
以上是小菜学习链表的代码了,给大家分享一下!!
C语言之链表的更多相关文章
- C语言习题 链表建立,插入,删除,输出
Problem B: C语言习题 链表建立,插入,删除,输出 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 222 Solved: 92 [Subm ...
- YTU 2430: C语言习题 链表建立,插入,删除,输出
2430: C语言习题 链表建立,插入,删除,输出 时间限制: 1 Sec 内存限制: 128 MB 提交: 576 解决: 280 题目描述 编写一个函数creatlink,用来建立一个动态链表 ...
- 关于c语言单项链表尾添加
犹豫了几天,看了很多大牛写的关于c语言链表,感触很多,终于下定决心,把自己对于链表的理解随之附上,可用与否,自行裁夺.由于作者水平有限也是第一次写,不足之处,竭诚希望得到各位大神的批评指正.制作不易, ...
- C语言之链表list
#include <stdio.h> #include <stdlib.h> #include <stdbool.h> #include <string.h& ...
- C语言:链表实现的一个实例
问题:写一个程序输入你一年看过的所有电影以及每部电影的各种信息(简化问题:每部电影只要求输入片名和评价) 链表实现: #include<stdio.h> #include<stdli ...
- C语言单链表实现19个功能完全详解
谢谢Lee.Kevin分享了这篇文章 最近在复习数据结构,想把数据结构里面涉及的都自己实现一下,完全是用C语言实现的. 自己编写的不是很好,大家可以参考,有错误希望帮忙指正,现在正处于编写阶段,一共将 ...
- (转)c语言_链表实例讲解(两个经典例子)
建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. #include <stdio.h>#include <stdlib.h> struct grade { ...
- Javascript模仿C语言的链表实现(增删改查),并且使用控制台输入输出
Js新手最近在研究Js数据结构,刚好看到链表实现这一块儿,觉得有些资料和自己理解的有冲突,于是借着自己以前一点点C语言的基础,用Javascript模仿了C的链表实现,并且用了process.stdi ...
- c语言_链表实例讲解(两个经典例子)
建立一个学生成绩的线性链表,对其实现插入,删除,输出,最后销毁. demo1 // lianbiao.cpp : Defines the entry point for the console app ...
随机推荐
- Python3.5 day3作业二:修改haproxy配置文件。
需求: 1.使python具体增删查的功能. haproxy的配置文件. global log 127.0.0.1 local2 daemon maxconn 256 log 127.0.0.1 lo ...
- 踏上Salesforce的学习之路(三)
一.创建Invoice对象 为了使我们的这个Warehouse app更加接近现实,我们现在为他创建一个Invoice对象. 先点击右上角的Setup,然后在左侧的Quick Find查找框中输入Ob ...
- java分享第十七天-03(封装操作mysql类)
JAVA操作mysql所需jar包:mysql-connector-java.jar代码: import java.sql.*; import java.util.ArrayList; import ...
- 第16周界面设计PSP总结
计划:需1周完整完成 需求分析:作为一个观众,我希望能够了解每一场的比分结果,随时跟进比赛进程 生成设计文档:暂无 设计复审:暂无与组员进行设计复审 代码规范:Visual Studio2010 具体 ...
- iOS 让按钮上的标题换行显示
项目中遇到了要让按钮上的文字换行显示的需求,就写了这个博客. 1.如果按钮上的文字固定,形式是写死的,可以考虑给标题文字加\n换行符来达到效果,但是,记得一定要设置这个属性,不然是不会换行的, but ...
- ARM 编译 phddns
参考博文http://bluegemyf.blog.163.com/blog/static/11816340201310472751513/ 1.安装必要的开发包 sudo apt-get inst ...
- 安装windows server 2012 r2 的那点事儿
windows server 2012 r2 安装无法找到install.wim 错误代码0x80070026,以及制作U启动盘决解ISO文件超过5G大小限制的解决方案 用UltaISO刻录后,sou ...
- C语言的傻瓜式随笔(一):嵌套循环-程序结构
循环语句的嵌套 一个循环结构内可以含有另一个循环,称为循环嵌套,又称多重循环.常用的循环嵌套是二重循环,外层循环称为外循环,内层循环称为内循环. ---------不知道哪来的基础概念 这是本宝宝的第 ...
- Node.js 框架
Node.js的是一个JavaScript平台,它允许你建立大型的Web应用程序. Node.js的框架平台使用JavaScript作为它的脚本语言来构建可伸缩的应用. 当涉及到Web应用程序的开发 ...
- JAVA的continue用法
JAVA的continue用法: public class test{ public static void main(String [] args){ for(int i=0;i<=10;i ...