C语言实现常用数据结构——链表
#include<stdio.h>
#include<stdlib.h> typedef struct Node {
int data;
struct Node *next;
} node; /*初始化链表:
1.首先给头指针分配空间,将头指针赋给temp
2.其次给每一个元素分配空间
3.将内容赋给当前节点的data,NULL赋给当前节点的next指针
4.把当前节点赋给(头指针)上一个节点的next指针
5.上一节点指针后移,准备初始化下个元素
6.最后返回当前链表的头指针*/
node *initnode() {
int i;
node *p = (node*)malloc(sizeof(node));
node *temp = p;
for (i = ; i < ; i++) {
node *a = (node*)malloc(sizeof(node));
a->data = i;
a->next = NULL;
temp->next = a;
temp = temp->next;
}
return p;
} /*指定位置插入元素:
1.将头指针赋给temp
2.temp一直遍历直到指定位置
3.给需要插入的元素分配空间,并将内容赋给分配好空间的元素
4.将插入位置的后一元素赋给要插入元素的next指针
5.将插入元素赋给temp的next指针
6.最后返回当前链表的头指针*/
node *insertElem(node *p, int elem, int pos) {
int i;
node *temp = p;
for ( i = ; i < pos; i++) {
temp = temp->next;
}
node *c = (node*)malloc(sizeof(node));
c->data = elem;
c->next = temp->next;
temp->next = c;
return p;
} /*删除指定位置的元素:
1.将头指针赋给temp
2.temp一直遍历直到指定位置
3.声明一个变量代表待删除节点
4.将待删除节点的下一节点赋给待删除节点的上一节点的next指针
5.释放待删除节点空间
6.最后返回当前链表的头指针*/
node *delElem(node *p, int pos) {
int i;
node *temp = p;
for ( i = ; i < pos; i++) {
temp = temp->next;
}
node *c = temp->next;
temp->next = c->next;
free(c);
return p;
} /*查询指定元素的位置:
1.将头指针赋给temp
2.temp一直遍历直到temp节点的值等于要查询的元素
3.返回当前节点的index
4.如果链表遍历结束也未找到指定节点,返回-1
*/
int selectElem(node *p, int elem) {
node *temp = p;
int i = ;
while (temp->next) {
temp = temp->next;
if (temp->data == elem) {
return i;
}
i++;
}
return -;
} /*更新链表指定节点的值*/
node *amendElem(node *p, int pos, int newElem) {
int i;
node *temp = p;
for ( i = ; i < pos; i++) {
temp = temp->next;
}
node *amend = temp->next;
amend->data = newElem;
return p;
} /*遍历链表*/
void display(node *p) {
node *temp = p;
while (temp->next) {
temp = temp->next;
printf("%d ", temp->data);
}
printf("\n");
} //以下内容来自《数据结构与算法-C语言描述》
int IsEmpty(node *p) {
return p->next==NULL;
} int IsLast(node *pos,node *p) {
return pos->next==NULL;
} //删除指定位置的元素
node *Delete(node *p,int elem) {
node *temp=p;
node *tmp;
while(temp->next) {
if(temp->next->data==elem) {
tmp=temp->next;
temp->next=tmp->next;
free(tmp);
}
temp=temp->next;
}
return p;
} //在指定位置插入元素
node *Insert(node *p,int pos,int elem) {
node *temp=p;
int i;
for(i=; i<pos; i++) {
temp=temp->next;
}
node *cell =(node*)malloc(sizeof(node));
cell->data=elem;
cell->next=temp->next;
temp->next=cell;
return p;
}
//删除list
void DeleteList(node *p) {
node *temp=p;
node *tmp;
p->next=NULL;
while(temp->next) {
tmp=temp->next;
free(tmp);
temp=temp->next;
}
} int main() {
node *p = initnode();
display(p);
printf("在第4的位置插入元素5:\n");
p = Insert(p, , );
display(p);
printf("删除第3个元素:\n");
p = delElem(p, );
display(p);
printf("查找元素2的位置为:\n");
int address = selectElem(p, );
if (address == -) {
printf("没有该元素\n");
} else {
printf("元素2的位子为:%d\n", address);
}
printf("更改第3的位置的数为7:\n");
p = amendElem(p, , );
display(p);
printf("delete7\n");
p=Delete(p,);
display(p);
printf("删除\n");
DeleteList(p);
display(p);
}
C语言实现常用数据结构——链表的更多相关文章
- C语言实现常用数据结构——图
#include<stdio.h> #include<stdlib.h> #define SIZE 20 #define LENGTH(a) (sizeof(a)/sizeof ...
- C语言实现常用数据结构——栈
#include<stdio.h> #include<stdlib.h> //用链表实现栈 typedef struct Node { int data; struct Nod ...
- 吴裕雄--天生自然数据结构与算法:java代码实现常用数据结构——链表Linked List
class Node{ // 定义节点类 private String data ; // 保存节点内容 private Node next ; // 表示保存下一个节点 public Node(St ...
- C语言实现常用数据结构——堆
#include<stdio.h> #include<stdlib.h> #define CAPACITY 20 /*堆有两个性质: * 1.结构性:堆必须是一颗完全二叉树 * ...
- C语言实现常用数据结构——二叉树
#include<stdio.h> #include<stdlib.h> #define SIZE 10 typedef struct Tree { int data; str ...
- C语言实现常用数据结构——队列
#include<stdio.h> #include<stdlib.h> #define MAX_SIZE 10 /* 用一个动态数组来实现队列 */ typedef stru ...
- 1. C语言中的数据结构.md
C语言内建数据结构类型 整型 整型数据是最基本的数据类型,不过从整形出发衍生出好几种integer-like数据结构,譬如字符型,短整型,整型,长整型.他们都是最基本的方式来组织的数据结构,一般是几位 ...
- Java 集合框架(常用数据结构)
早在Java 2中之前,Java就提供了特设类.比如:向量(Vector).栈(Stack).字典(Dictionary).哈希表(Hashtable)这些类(数据结构)用来存储和操作对象组.虽然这些 ...
- C++常用数据结构的实现
常用数据结构与算法的实现.整理与总结 我将我所有数据结构的实现放在了github中:Data-Structures-Implemented-By-Me 常用数据结构与算法的实现.整理与总结 KMP字符 ...
随机推荐
- 华为软件开发云(DevCloud):免费可商用的项目管理工具
在软件开发技术和理念层出不穷的今天,如何更快的适应变化的环境,更好的满足客户的需求,已经成为决定从小到大各种规模企业能否活下去的关键. 天下武功唯快不破,在当今大环境中更是如此,微服务,敏捷开发,新的 ...
- [Cordova+Sencha Touch] 移动开发1 sencha 2.4.0 + 在 安卓2.3.6上使用报错 - has no method 'bind'
Sencha Touch 2.3.2和2.4.0在安卓2.3上面用会报错,具体报错信息如下: 解决办法是: 打开文件:你的file:///android_asset/www/sencha-touch- ...
- SecureCRT 专题
SecureCRT在同一窗口打开多个标签:选中“在标签页中打开”即可 SecureCRT同时向多个tab窗口发送相同的命令 Step by step: 作为管理N台服务器,而又要执行相同命令又不想用脚 ...
- 用ORACHK自己主动化检查数据库系统的健壮性
1.orachk工具主要用途 (1)主动检查您的整个软件在操作系统.CRS.数据库.高可用等层面中的严重问题,以便于IT部门整改,提升系统的稳定性 (2)对于您系统中存在的风险提供简单化和合理化的诊断 ...
- Qt Installer Framework 3.0.1 Released(功能比较强)
We are happy to announce the release of Qt IFW 3.0.1. 3.0.1 is fully compatible with 2.0.5, which me ...
- WPF 路由事件 Event Routing
原文:WPF 路由事件 Event Routing 1.路由事件介绍 之前介绍了WPF的新的依赖属性系统,本篇将介绍更高级的路由事件,替换了之前的.net普通事件.相比.net的事件,路由事件具有更强 ...
- python_简单的DB统计
import numpy as npimport pylab as pldates=['20170314','20170315','20170316','20170317','20170318','2 ...
- Python+Django+SAE系列教程10-----Django模板
在本章中,我们开始模板,在前面的章节,您可能已经注意到,我们回到文本的方式有点特别的示例视图. 那.HTML直接在硬编码 Python 其中代码. 这的确是一个小BT. def current_dat ...
- Nucleus PLUS系统架构和组件
(一个)方法论和软件组件 1.软件组件(Software Component)定义 从一般意义上来说.组件(Component)是系统中能够明白辨识的组成部分,一个不透明的功能实现体.软件开发中,组件 ...
- 从PRISM开始学WPF(番外)共享上下文 RegionContext?
原文:从PRISM开始学WPF(番外)共享上下文 RegionContext? RegionContext共享上下文 There are a lot of scenarios where you mi ...