C语言数据结构-顺序线性表的实现-初始化、销毁、长度、查找、前驱、后继、插入、删除、显示操作
1、数据结构-顺序线性表的实现-C语言
#define MAXSIZE 100
//结构体定义
typedef struct
{
int *elem; //基地址
int length; //结构体当前长度
int listsize; //结构体最大长度
} Sqlist; //结构体类型名
//各项操作
void Show_Help()
{
printf("1---初始化线性表\n");
printf("2---销毁线性表\n");
printf("3---清空线性表\n");
printf("4---判断线性表是否为空\n");
printf("5---求线性表长度\n");
printf("6---获取线性表某位置元素\n");
printf("7---请输入元素的值,判断其在线性表中是否存在,并返回其下标,不存在则返回0\n");
printf("8---求直接前驱\n");
printf("9---求直接后继\n");
printf("10---在线性表指定位置插入元素\n");
printf("11---删除线性表指定位置元素\n");
printf("12---显示线性表全部元素\n");
printf("13---翻转线性表全部元素\n");
printf("退出,输入一个负数\n");
}
//初始化线性表
void InitList(Sqlist* L)
{
L->elem = (int*) malloc(MAXSIZE*sizeof(int)); //给线性表分配初始空间
if(!(L->elem)){
printf("分配失败\n");
return ;
}
L->length = 0;
L->listsize = MAXSIZE;
}
//销毁线性表
void DestroyList(Sqlist* L)
{
if(L->elem)
free(L->elem); //销毁只需释放刚才给基地址分配的空间即可
L->length = 0;
}
//清空线性表
void ClearList(Sqlist* L)
{
L->length = 0;
}
//判断线性表是否为空
int ListEmpty(Sqlist L)
{
if(L.length)
return 0;
else
return 1;
}
//求线性表长度
int ListLength(Sqlist L)
{
return L.length;
}
//获取线性表某位置元素
void GetElem(Sqlist L,int i,int* e)
{
e = L.elem[i-1];
}
//请输入元素的值,判断其在线性表中是否存在,并返回其下标,不存在则返回0
int LocateElem(Sqlist L,int e)
{
int position = 0;
for(int i=0; i<L.length; i++)
{
if(L.elem[i] == e)
{
position = i+1;
break;
}
}
return position;
}
//求直接前驱
void PriorElem(Sqlist L,int cur_e,int* pre_e)
{
pre_e = L.elem[cur_e-2];
}
//求直接后继
void NextElem(Sqlist L,int cur_e,int* next_e)
{
next_e = L.elem[cur_e];
}
//在线性表指定位置插入元素
void ListInsert(Sqlist* L,int i,int e)
{
for(int j=L->length; j>=i; j--)
{
L->elem[j] = L->elem[j-1];
}
L->elem[i-1] = e;
L->length++;
}
//删除线性表指定位置元素
void ListDelete(Sqlist* L,int i)
{
for(int j=i-1; j<L->length-1; j++)
{
(*L).elem[j] = (*L).elem[j+1];
}
L->length--;
}
//显示线性表全部元素
void TraverList(Sqlist L)
{
printf("线性表中的元素有:");
for(int i=0; i<L.length; i++)
{
printf("%d ",L.elem[i]);
}
printf("\n");
}
//翻转线性表全部元素
void Flip(Sqlist L)
{
int num = L.length / 2;
int* begin = &L.elem[num-1];
int* end = &L.elem[L.length-num];
int middle;
while(num)
{
middle = *begin;
*begin = *end;
*end = middle;
num--;
begin = &L.elem[num-1];
end = &L.elem[L.length-num];
}
printf("翻转成功\n");
}
欢迎转载,转载请标明出处哦
C语言数据结构-顺序线性表的实现-初始化、销毁、长度、查找、前驱、后继、插入、删除、显示操作的更多相关文章
- c语言数据结构之线性表的顺序存储结构
线性表,即线性存储结构,将具有“一对一”关系的数据“线性”地存储到物理空间中,这种存储结构就称为线性存储结构,简称线性表. 注意:使用线性表存储的数据,要求数据类型必须一致,线性表存储的数据,要么全不 ...
- 线性表&顺序线性表
第二章 线性表 参考文献:[数据结构(C语言版)].严蔚敏 本篇章仅为个人学习数据结构的笔记,不做任何用途. 2.1 线性结构的特点 (1). 存在唯一的一个被称为"第一个"的数据 ...
- 【C语言--数据结构】线性顺序表
线性表的本质: 1.线性表(List)是零个或者多个数据元素的集合: 2.线性表中的数据元素之间是有顺序的: 3.线性表中的数据元素个数是有限的: 4.线性表中的数据元素的类型必须相同: 定义: 线性 ...
- 动态分配的顺序线性表的十五种操作—C语言实现
线性表 定义:是最常用的,也是最简单的数据结构,是长度为n个数据元素的有序的序列. 含有大量记录的线性表叫文件 记录:稍微复杂的线性表里,数据元素为若干个数据项组成,这时把一个数据元素叫记录 结构特点 ...
- 算法与数据结构(一) 线性表的顺序存储与链式存储(Swift版)
温故而知新,在接下来的几篇博客中,将会系统的对数据结构的相关内容进行回顾并总结.数据结构乃编程的基础呢,还是要不时拿出来翻一翻回顾一下.当然数据结构相关博客中我们以Swift语言来实现.因为Swift ...
- Java数据结构之线性表
从这里开始将要进行Java数据结构的相关讲解,Are you ready?Let's go~~ java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来的 ...
- 顺序线性表 ---- ArrayList 源码解析及实现原理分析
原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7738888.html ------------------------------------ ...
- 用C#学习数据结构之线性表
什么是线性表 线性表是最简单.最基本.最常用的数据结构.线性表是线性结构的抽象(Abstract),线性结构的特点是结构中的数据元素之间存在一对一的线性关系.这种一对一的关系指的是数据元素之间的位置关 ...
- 顺序线性表之大整数求和C++
顺序线性表之大整数求和 大整数求和伪代码 1.初始化进位标志 flag=0: 2.求大整数 A 和 B 的长度: int aLength = a.GetLength(); int bLength = ...
随机推荐
- Git学习笔记(二)分支管理与合并及Bug分支
一.分支管理 1.什么是分支 分支就相当于我们看科幻片里的平行宇宙,如果两个平行宇宙互不干扰,那铁定是啥事儿没有.不过,在某个时间点,两个平行宇宙合并了呢?假如两个宇宙中都有你的影子, 合并之后相当于 ...
- java 多线程系列基础篇(九)之interrupt()和线程终止方式
1. interrupt()说明 在介绍终止线程的方式之前,有必要先对interrupt()进行了解.关于interrupt(),java的djk文档描述如下:http://docs.oracle.c ...
- 12-21C#电脑蓝屏效果(可以恶搞整人哦)、输入输出流(StreamReader/streamWriter)
一.winform电脑蓝屏效果 第一种方法:基本操作: 第一步:创建一个新的C#窗体“Form1”: 第二步:在设计窗口中,更改其属性: 1)text属性:将form1的text属性中的文字取消掉,然 ...
- 10-13C#语句(1)
C#语句:判断.循环.形成程序的分支和循环 1.语句分类 1)顺序语句 2)分支语句 3)循环语句 2.语句 选择控制:if,else,switch,case 循环控制:while,do,for,fo ...
- 使用Eclipse中遇到的问题
1.解决eclipse中jsp没有代码提示问题 原因是项目没有关联TOMCAT库文件: 右键项目—> 属性->JAVA Build Path -> Add Library->S ...
- 从文件中读取yuv和h264数据
1.从文件中读取h264数据 参考ffmpeg avc.c写的从文件中一帧帧读取h.264数据的demo #include <stdio.h> #include <stdlib.h& ...
- Android源码中添加C可执行程序
在Android源码中添加C/CPP可执行程序一般保存在external目录中 下面是每个文件的内容 ①add.c #include "add.h" int add (int a, ...
- DAY12-前端之CSS
CSS介绍 CSS(Cascading Style Sheet,层叠样式表)定义如何显示HTML元素. 当浏览器读到一个样式表,它就会按照这个样式表来对文档进行格式化(渲染). CSS语法 CSS实例 ...
- eclipse中创建maven web项目
本文主要说明将maven web项目转成eclipse支持的web项目. 创建一个maven项目设置打包类型为war则其为web项目 结构如下 将mavenweb项目转成eclipse识别的web项目 ...
- JAVA基础知识总结13(同步)
好处:解决了线程安全问题. 弊端:相对降低性能,因为判断锁需要消耗资源,还容易产生了死锁. 定义同步是有前提的: 1,必须要有两个或者两个以上的线程,才需要同步. 2,多个线程必须保证使用的是同一个锁 ...