C/C++单向链表
由于时间仓促,作者并没有进行任何的检查,总之徒手165行,调试无BUG,基本功能的实现并无大问题,可能有些细节考虑不周(这也是C/C++的诟病,小车不倒只管前推),还忘见谅。
代码是在C++环境编写,可以在C编译平台运行,但要进行修改(把声明变量语句,写在执行语句之前)。
#include <stdio.h>
#include <stdlib.h>
//定义节点,所有节点必须用malloc()申请在堆中,在程序执行阶段保证空间的存在;
//-1表示非正常退出
typedef struct node
{
int data;
node *next;
} Node;
//用来表示链表的长度,-1表示无头节点的空表
int len = -;
//定义一个全局头结点
Node *head = NULL; //创建一个带有头节点的空链表
void createNodeList()
{
if (head != NULL)//表示为非空表
exit(-);//非正常退出
head = (Node *)malloc(sizeof(Node));//申请堆空间
if (head == NULL) //如果head==NULL则申请失败
exit(-);
//头结点的数据域为0,指针域为NULL
head->data = ;
head->next = NULL;
len = ;//0表示有头节点的空表 } //添加一个节点(向当前节点的指针域为NULL的节点后面添加)
void addNode(int data)
{
if (head == NULL)//表示为空表
exit(-);
Node *newNode = (Node *)malloc((sizeof(Node)));//创建一个新节点
if (newNode == NULL)//申请失败
exit(-);
//初始化新结点的数据域和指针域
newNode->data = data;
newNode->next = NULL;
//连接工作
Node *p = head;//当前节点
Node *q = head->next;//下一个节点
while (q != NULL)
{
//循环成立表示当前结点的指针域不为NULL
p = q;//更新当前结点
q = p->next;//更新当前结点的
}
//循环结束表示当前节点的指针域为NULL
//更新当前节点指针域为新结点
p->next = newNode;
len++;//表长加一
}
//获取节点数据(0<index<len)
int getNode(int index)
{
int data = -;
if (head == NULL)//表示为空表
exit(-);
if (index < )//下标要从0开始
exit(-);
if (index >= len)//下标越界
exit(-);
Node *p = head->next;
data = p->data;
for (int i = ; i < index;i++)
{
p=p->next;
}
data = p->data;
return data;
}
//元素查找
int getData(int data)
{
if (head == NULL)//表示为空表
exit(-);
Node *p = head->next;//表示第一个节点
for (int i = ;p!=NULL;i++)
{
if (p->data==data)
return i;//返回下标
p = p->next;
}
}
//向屏幕打印链表
void getLinks()
{
if (head == NULL)//表示为空表
exit(-);
//指向第一个节点
Node *p = head->next;
//如果该结节不为NULL则表示存在该节点
while (p != NULL)
{
printf("%d\n", p->data);
p = p->next;
}
}
//删除节点
void removeNode(int index)
{
if (head == NULL)//表示为空表
exit(-);
if (index < )//下标要从0开始
exit(-);
if (index >= len)//下标越界
exit(-);
//p表示当前节点,q表示当前节点的指针域
Node *p = head;//要被删除的前一个节点
Node *q = head->next;//要被删除的节点
for (int i = ; i < index;i++)
{
p = q;
q = p->next;
}
//重新连接
p->next = q->next;
free(q);//删除q节点
len--;//表长减一
}
//清空链表
void cleanLinks()//表示为空表
{
if (head == NULL)
exit(-); Node *p = head;//当前节点
Node *q=head->next;//下一个节点
free(p);//删除当前节点
while (q!=NULL)
{
p = q;
q = p->next;
free(p);//删除当前节点
}
len = -;//表示该表为空
}
void main()
{
//创建表
createNodeList();
//添加元素
addNode();
addNode();
addNode();
addNode();
//打印表,和表长
getLinks();
printf("len:%d\n", len);
//查看第三个节点"4"
printf("index 3:%d\n",getNode());
//数据4所在节点下标
printf("data 4:%d\n",getData());
//删除第三个元素”3“
removeNode();
//分隔符
printf("=============\n");
//再次打印表和表长
getLinks();
printf("len:%d\n", len);
cleanLinks();
system("pause");
}
C/C++单向链表的更多相关文章
- Reverse Linked List II 单向链表逆序(部分逆序)
0 问题描述 原题点击这里. 将单向链表第m个位置到第n个位置倒序连接.例如, 原链表:1->2->3->4->5, m=2, n =4 新链表:1->4->3-& ...
- 【编程题目】输入一个单向链表,输出该链表中倒数第 k 个结点
第 13 题(链表):题目:输入一个单向链表,输出该链表中倒数第 k 个结点.链表的倒数第 0 个结点为链表的尾指针.链表结点定义如下: struct ListNode {int m_nKey;Lis ...
- 输出单向链表中倒数第k个结点
描述 输入一个单向链表,输出该链表中倒数第k个结点,链表的倒数第0个结点为链表的尾指针. 链表结点定义如下: struct ListNode { int m_nKey; ListNode* ...
- Linus:利用二级指针删除单向链表
Linus大神在slashdot上回答一些编程爱好者的提问,其中一个人问他什么样的代码是他所喜好的,大婶表述了自己一些观点之后,举了一个指针的例子,解释了什么才是core low-level codi ...
- 【转】Linus:利用二级指针删除单向链表
原文作者:陈皓 原文链接:http://coolshell.cn/articles/8990.html 感谢网友full_of_bull投递此文(注:此文最初发表在这个这里,我对原文后半段修改了许多, ...
- C语言实现单向链表及其各种排序(含快排,选择,插入,冒泡)
#include<stdio.h> #include<malloc.h> #define LEN sizeof(struct Student) struct Student / ...
- 数据结构——Java实现单向链表
结点类: /** * @author zhengbinMac * 一个OnelinkNode类的对象只表示链表中的一个结点,通过成员变量next的自引用方式实现线性表中各数据元素的逻辑关系. */ p ...
- 输入一个单向链表,输出该链表中倒数第K个结点
输入一个单向链表,输出该链表中倒数第K个结点,具体实现如下: #include <iostream> using namespace std; struct LinkNode { publ ...
- 单向链表JAVA代码
//单向链表类 publicclassLinkList{ //结点类 publicclassNode{ publicObject data; ...
- C++ 单向链表反转
单向链表反转,一道常见的面试题,动手实现下. #include "stdafx.h" #include <stdlib.h> struct Node{ int data ...
随机推荐
- SOA、微服务与服务网格
SOA架构解析 SOA 全称是: Service Oriented Architecture,中文释义为 “面向服务的架构”,它是一种设计理念,其中包含多个服务, 服务之间通过相互依赖最终提供一系列完 ...
- [转]【技术心得】Last-Modified,Etag,Expire区别
Last-Modified 是什么 Last-Modified 是 HttpHeader 中的资源的最后修改时间,如果带有 Last-Modified ,下一次发送 Http 请求时,将会发生带 If ...
- 使用ajax技术实现简单登录操作
1.ajax:特点在web上面通过JavaScript,使用异步的XmlHttp请求,实现无刷新的Web界面 首先:创建ajax对象 再次:向服务器端实现ajax请求 最后:回调 创建异步请求对象 & ...
- jenkins插件
构建maven项目:Maven Release Plug-in Plug-in
- Spring MVC 项目示例
Spring MVC是Spring Framework的一部分,是基于Java实现MVC的轻量级Web框架.Spring的web框架围绕DispatcherServlet设计, 作用是将请求分发到不同 ...
- python学习笔记(二):python数据类型
上一篇博客写了python的入门和简单流程控制,这次写python的数据类型和各种数据类型的内置方法.一.数据类型是什么鬼?计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各 ...
- catkin 工作空间
catkin 工作空间:组织和管理功能包的文件夹,以 catkin 工具编译 建立工作空间 sch01ar@ubuntu:~$ mkdir -p ~/catkin_ws/src sch01ar@ubu ...
- 无人零售的黑科技:RFID技术
无人零售的黑科技:RFID技术说起最近的热门话题,“无人零售商店”当属其一.自去年底,亚马逊推出第一家无人实体超市Amazon Go,到阿里.京东.大润发等各大企业纷纷加入,无人商店被推上了风口浪尖. ...
- noip2017D2T3的几种写法...(BIT/线段树/平衡树)
题意各大oj上都有啦..想必来搜题解的都看过题面了...Qw Solution1: 首先观察n=1的情况,显然就是中间删掉一个数后面加上一个数,并查询那个删掉的数(以后把这样一个过程称为一个操作啦(( ...
- Struts2 结合 Freemarker 实例
Freemarker 是一个不依赖 web 容器的模板引擎,一个基于模板生成文本输出的工具.其工作的原理如下图: freemarker 不是一个 web 应用的框架,而适合作为 web 应用的一个组 ...