线性表的顺序存储和链式存储的实现(C)
//线性表的顺序存储
#include <stdio.h>
typedef int DataType;
#define MaxSize 15
//定义顺序表
typedef struct
{
DataType List [MaxSize];
int Size;
}Slist;
//初始化顺序表
void ListInit(Slist * S)
{
S->Size=0;
}
//插入数据
int ListInsert(Slist *S ,int i,DataType x)
{ int j;
if(i<0||i>S->Size)
{
printf("插入位置不正确!");
return 0;
}
else
{
for(j=S->Size;j>i;j--)
{
S->List[j]=S->List[j-1];
}
S->List[i]=x;
S->Size++;
return 1;
}
}
//取得元素个数
int ListLength(Slist *S)
{
return S->Size;
}
//删除元素
int ListDelete(Slist *S,int i,DataType *x)
{ int j;
if(i<0||i>S->Size-1)
{
printf("删除位置不正确!");
return 0;
}
else
{ //保存删除的数据到x所指的变量中;
*x=S->List[i];
for(j=i;j<S->Size-1;j++)
{
S->List[j]=S->List[j+1] ;
}
S->Size--;
return 1;
}
}
//取得顺序表中的元素
int ListGet(Slist *S,int i,DataType *x)
{
if(i<0||i>S->Size-1)
{
printf("没有这个元素!");
}
else
{
*x=S->List[i];
return 0;
}
}
//主函数
int main ()
{
//定义一个结构体变量
Slist mylist;
int x,b,i;
//初始化
ListInit(&mylist);
//插入数据
for(i=0;i<10;i++)
ListInsert(&mylist,i,i+6);
//取得数据元素个数
b=ListLength(&mylist);
printf("顺序表中的元素个数为:");
printf("%d \n",b);
//取得插入的数据
for(i=0;i<ListLength(&mylist);i++)
{
ListGet(&mylist,0,&x);
printf("%d \n",x);
}
return 0;
}
//线性表的链式存储
#include<stdio.h>
#include<malloc.h>
//定义链式表的结构体
typedef int DataType ;
typedef struct snode
{ DataType data;
struct snode *next;
} Lnode;
//进行初始化
void ListInit(Lnode **head)
{
*head=(Lnode*)malloc(sizeof(Lnode)); //头指针
(*head)->next=NULL;
}
//插入数据
int ListInsert(Lnode *head,int i,DataType x)
{
int j;
Lnode *p,*q;
p=head;
j=-1;
while(p->next!=NULL&&j<i-1)
{
p=p->next;
j++;
}
if(j!=i-1)
{
printf("插入的位置不对,请重新插入");
return 0;
}
q=(Lnode*)malloc(sizeof(Lnode)); //申请一个节点
q->data=x;
q->next=p->next;
p->next=q;
return 1;
}
//取得元素个数
int ListLength(Lnode *head)
{
Lnode *p;
int size=0;
p=head;
while(p->next!=NULL)
{
p=p->next;
size++;
}
return size;
}
//删除数据
int ListDelete(Lnode *head,int i,DataType *x)
{
Lnode *p,*q;
int j;
p=head;
j=-1;
while(p->next!=NULL&&j<i)
{
p=p->next;
j++;
}
if(j!=i-1)
{
printf("删除的位置不对!");
return 0;
}
q=p->next;
*x=p->data;
p->next=p->next->next;
free(q);
return 1;
}
//取得元素
int ListGet(Lnode* head,int i,DataType *x)
{
Lnode *p;
int j;
p=head;
j=-1;
while(p->next!=NULL&&j<i)
{
p=p->next;
j++;
}
if(j!=i)
{
printf("取元素位置参数有误!");
return 0;
}
*x=p->data;
return 1;
}
//销毁数据链
void ListDestroy(Lnode **head)
{
Lnode *p,*q;
p=*head;
while(p!=NULL)
{ q=p;
p=p->next;
free (q);
}
*head=NULL;
}
//主函数
void main ()
{
Lnode *mylist;
int i,x,s;
//初始化链表
ListInit(&mylist);
//插入数据
for(i=0;i<10;i++)
ListInsert(mylist,i,i+1);
//取得数据个数
s= ListLength(mylist);
printf("元素个数为:%d \n",s);
//取得所有数据
for(i=0;i<ListLength(mylist);i++)
{
ListGet(mylist,i,&x) ;
printf("%d\n",x);
}
}
线性表的顺序存储和链式存储的实现(C)的更多相关文章
- 数据结构导论 四 线性表的顺序存储VS链式存储
前几章已经介绍到了顺序存储.链式存储 顺序存储:初始化.插入.删除.定位 链式存储:初始化.插入.删除.定位 顺序存储:初始化 strudt student{ int ID://ID char nam ...
- 算法与数据结构(一) 线性表的顺序存储与链式存储(Swift版)
温故而知新,在接下来的几篇博客中,将会系统的对数据结构的相关内容进行回顾并总结.数据结构乃编程的基础呢,还是要不时拿出来翻一翻回顾一下.当然数据结构相关博客中我们以Swift语言来实现.因为Swift ...
- 线性表的顺序存储和链式存储c语言实现
一.线性表的顺序存储 typedef int ElemType;typedef struct List { ElemType *data;//动态分配 ,需要申请空间 int length; }Lis ...
- 线性表的Java实现--链式存储(单向链表)
单向链表(单链表)是链表的一种,其特点是链表的链接方向是单向的,对链表的访问要通过顺序读取从头部开始. 链式存储结构的线性表将采用一组任意的存储单元存放线性表中的数据元素.由于不需要按顺序存储,链表在 ...
- c数据结构 -- 线性表之 复杂的链式存储结构
复杂的链式存储结构 循环链表 定义:是一种头尾相接的链表(即表中最后一个结点的指针域指向头结点,整个链表形成一个环) 优点:从表中任一节点出发均可找到表中其他结点 注意:涉及遍历操作时,终止条件是判断 ...
- 线性表的Java实现--链式存储(双向链表)
有了单向链表的基础,双向链表的实现就容易多了. 双向链表的一般情况: 增加节点: 删除节点: 双向链表的Java实现: package com.liuhao.algorithm; publi ...
- C 数据结构1——线性表分析(顺序存储、链式存储)
之前是由于学校工作室招新,跟着大伙工作室招新训练营学习数据结构,那个时候,纯碎是小白(至少比现在白很多)那个时候,学习数据结构,真的是一脸茫然,虽然写出来了,但真的不知道在干嘛.调试过程中,各种bug ...
- Java实现线性表-顺序表示和链式表示
顺序表示和链式表示的比较: 1.读写方式:顺序表可以顺序存取,也可以随机存取:链表只能从表头顺序存取元素: 2.逻辑结构与物理结构:顺序存储时,逻辑上相邻的元素其对应的物理存储位置也相邻:链式存储时, ...
- 队列的顺序存储与链式存储c语言实现
一. 队列 1.队列定义:只允许在表的一端进行插入,表的另一端进行删除操作的线性表. 2.循环队列:把存储队列的顺序队列在逻辑上视为一个环. 循环队列状态: 初始时:Q.front=Q.rear=0 ...
随机推荐
- [LUOGU] 2820 局域网
题目背景 某个局域网内有n(n<=100)台计算机,由于搭建局域网时工作人员的疏忽,现在局域网内的连接形成了回路,我们知道如果局域网形成回路那么数据将不停的在回路内传输,造成网络卡的现象.因为连 ...
- Linux 特殊权限位简介
suid.guid suid 针对二进制命令或者程序,让其拥有root或者属主权限执行 一.setsuid : chmod 4755 二进制命令或者程序 chmod u+s 二进制命令或者程序 示 ...
- sklearn 快速入门教程
1. 获取数据 1.1 导入sklearn数据集 sklearn中包含了大量的优质的数据集,在你学习机器学习的过程中,你可以通过使用这些数据集实现出不同的模型,从而提高你的动手实践能力,同时这个过程也 ...
- '>>' should be '> >' within a nested template argument list
在编译关于opencv相机标定的工程的时候出现了这个问题 vector<vector<Point3f>> objectPoints; error: 'objectPoint ...
- Codeforces Round #439 (Div. 2) E. The Untended Antiquity
E. The Untended Antiquity 题目链接http://codeforces.com/contest/869/problem/E 解题心得: 1.1,x1,y1,x2,y2 以(x1 ...
- Hive元数据启动失败,端口被占用
org.apache.thrift.transport.TTransportException: Could not create ServerSocket on address 0.0.0.0/0. ...
- Thymeleaf模板引擎+Spring整合使用方式的介绍
尊重原创,原文地址为:https://www.cnblogs.com/jiangchao226/p/5937458.html 前言 这个教程介绍了Thymeleaf与Spring框架的集成,特别是Sp ...
- 使用Phaser开发你的第一个H5游戏(一)
本文来自网易云社区 作者:王鸽 不知你是否还记得当年风靡一时的2048这个游戏,一个简单而又不简单的游戏,总会让你在空闲时间玩上一会儿. 在这篇文章里,我们将使用开源的H5框架--Phaser来重现这 ...
- Python内置函数5
Python内置函数5 1.format参考前面字符串方法中的format 2.frozenset([iterable]) iterable -- 可迭代的对象,比如列表.字典.元组等等 返回一个冻结 ...
- iOS WKWebView
Webkit 是 iOS 8.0 后提供的新的框架,组件WKWebView比较UIWebView 速度更快.占用内存更少了,可支持性更多 WKWebView可通过KVO监听属性 title.estim ...