首页 > 其他分享 >数据结构-C语言

数据结构-C语言

时间:2023-03-14 18:55:14浏览次数:49  
标签:Lb 线性表 La 元素 len C语言 数据结构 数据

一、基本定义

1、数据

数据:是对客观事物的符号表示,在计算机科学中是指所有能输入到计算机中并被计算机程序处理的符号的总称。

数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。

数据元素:数据的基本单元

数据项:一个元素可由若干个数据项组成,是数据的不可分割的最小单位。

数据对象:性质相同的数据元素的集合,是数据的一个子集。

数据元素都不是孤立存在的,它们之间存在某种关系,称为结构。

2、根据数据元素之间关系的不同特性,有4种基本结构:

1)集合:除了‘同属于一个集合’关系外,别无其它关系;
2)线性结构:一对一关系;
3)树形结构:一对多关系;
4)图状结构或网状结构:多个对多个关系;

3、数据元素之间的关系在计算机中有两种不同的表示方法:顺序映像和非顺序映像。

并由此得到两种不同的存储结构:顺序存储结构(相对位置)和链式存储结构(指示元素存储地址的指针)。顺序和链路在一种存储算法中只能用一种。

顺序映像特点:借助元素在存储器中的相对位置来表示数据元素之间的逻辑关系;

非顺序映像特点:借助指示元素存储地址的指针来表示数据元素之间的逻辑关系。

4、数据类型:用以刻画(程序)操作对象的特征。是一个值的集合和定义在这个值集上的一组操作的总称。

1)抽象数据类型(abstract data type,简称ADT):指一个数学模型以及定义在该模型上的一组操作。

抽象数据类型表示:可用三元组(D,S,P),D是数据对象,S是D上的关系集,P是对D的基本操作集。

定义抽象数据类型:

ADT 抽象数据类型名{
    数据对象:<数据对象的定义>
    数据关系:<数据关系的定义>
    基本操作:<基本操作的定义>
}ADT 抽象数据类型名

数据对象和数据关系的定义用伪码描述。

基本操作的定义格式为:对于引用参数,定义前加&,调用时不要加&。

基本操作名(参数表)
    初始条件:<初始条件描述>
    操作结果:<操作结果描述>

数据结构的表示(存储结构)用类型定义(typedef)描述。

status是函数的类型,其值是函数结果状态代码。typedef int status; Elemtype:数据元素类型约定为Elemtype。

基本操作的算法:

函数类型 函数名(函数参数表){
    //算法说明
    语句序列
}//函数名

输入输出等语句:

scanf([格式串],变量1,...,变量n);
printf([格式串],表达式1,...,表达式n);
floor(表达式) //求不足整数值
ceil(表达式)  //求进位整数值
eof(文件变量)或eof      //判定文件结束
eoln(文件变量)或eoln  //判定行结束

基本操作的实现:

Status InitTriplet(Triplet &T,ElemType v1,ElemType v2,ElemType v3){
    //构造三元组T,依次置T的3个元素的初始值为v1,v2,v3。
    T=(ElemType *) malloc(3*sizeof(ElemType));  //分配3个元素的存储空间
    if (!T) exit(OVERFLOW);   //分配存储空间失败
    T[0]=v1; T[1]=v2; T[2]=v3;
    return OK;
}//InitTriplet
Status DestroyTriplet(Triplet &T){
    //销毁三元组T
    free(T); T=NULL;
    return OK;
}//DestroyTriplet
Status Get(Triplet T,int I,ElemType &e){
    //1≤I≤3,用e返回T的第i元的值。
    if(i<1 || i>3)return ERROR;
    e=T[i-1];
    return OK;
}//Get

5、算法algorithm

是对特定问题求解步骤的一种描述,是指令的有限序列,其中每一条指令表示一个或多个操作;

算法具有5个特性:有穷性,不确定性,可行性,输入,输出。

算法设计的要求:正确性,可读性,健壮性,效率与低存储量需求;

算法效率的度量:时间复杂度T(n)=O(f(n))    //表示随问题规模n的增大,算法执行时间的增长率和f(n)的增长率相同

算法的存储空间需求:空间复杂度S(n)=O(f(n))

算法的执行时间=∑原操作(i)的执行次数

二、线性表

1、线性表的类型定义

线性结构的特点:在数据元素的非空有限集中,(1)存在唯一的一个被称作“第一个”的数据元素;(2)存在唯一的一个被称作“最后一个”的数据元素;(3)除第一个之外,集合中的每个数据元素均只有一个前驱;(4)除最后一个之外,集合中每个数据元素均只有一个后继。

基本线性结构有:线性表、栈、队列、串、数组、广义表、树、二叉树、图等。

抽象数据类型的线性表的定义:
ADT List{
    数据对象:D={a
i
 | a
i
属于ElemSet,i=1,2,...n,n≥0}
    数据关系:R1={a
i-1
,a
i
>|a
i-1
,a
i
属于D,i=2,...n}   //i-1为下标。
    基本操作:
        InitList(&L)
            操作结果:构造一个空的线性表L。
}ADT List

算法:

void union(List &La,List Lb){
    //将所有在线性表Lb中但不在La中的数据元素插入到La中
    La_len=ListLength(La),Lb_len=ListLength(Lb); //求线性表的长度
    for(i=1;i<Lb_len;i++){
        GetElem(Lb,i,e);  //取Lb中第i个元素赋给e
        if(!LocateElem(La,e,equal))ListInsert(La,++La_len,e);
            //La中不存在和e相同的数据元素,则插入之。
    }
}//union
时间复杂度O(La_len*Lb_len)
void MergeList(List La,List Lb,List &Lc){
    //已知线性表La和Lb中数据元素按值非递减排列
    //归并La和Lb得到新的线性表Lc,Lc的数据元素也按值非递减排列
    InitList(Lc);
    i=j=1;k=0;
    La_len=ListLength(La);Lb_len=ListLength(Lb);
    while((i<La_len)&&(j≤Lb_len)){//La和Lb均非空
        GetElem(La,i,ai);GetElem(Lb,j,bj);
        if(ai<bj){ListInsert(Lc,++k,ai);++i;}
        else{ListInsert(Lc,++k,bj);++j;}
    }
    while(i≤La_len){
        GetElem(La,i++,ai);ListInsert(Lc,++k,ai);
    }
    while(j≤Lb_len){
        GetElem(Lb,j++,bj);ListInsert(Lc,++k,bj);
    }
}//MergeList
时间复杂度O(La_len+Lb_len)

2、线性表的顺序表示和实现

线性表的顺序表示指:用一组地址连续的存储单元依次存储线性表的数据元素。以所占的第一个单元的存储地址作为数据元素的存储地址。

弱点:在做插入或删除操作时,需移动大量元素。

//----------线性表的动态分配顺序存储结构----------
#define LIST_INIT_SIZE 100    //线性表存储空间的初始分配量
#define LISTINCREMENT 10     //线性表存储空间的分配增量
typedef struct {     //typedef关键字,struct结构体  
    ElemType *elem;    //存储空间基址,初始地址
    int length;     //当前长度
    int listsize;    //当前分配的存储容量(以sizeof(ElemType)为单位)
}//SqList;

 

标签:Lb,线性表,La,元素,len,C语言,数据结构,数据
From: https://www.cnblogs.com/min222/p/17081069.html

相关文章

  • Linux & 标准C语言学习 <DAY13>
    一、字符串  字符:类字形单位或符号,包括字母、数字、运算符号、标点符号和其他符号,以及一些功能性符号  串:是一种数据结构,存储类型相同的若干个数据,对于串型结构......
  • 数据结构笔记
    数据结构笔记二叉树遍历方式:前序遍历:打印-左-右中序遍历:左-打印-右后序遍历:左-右-打印Pair头文件:#includepair<类型1,类型2>变量名;pair<int,int>a(......
  • C语言代码规范
    一、问题引入初入编程世界,我们不知道什么叫做好代码。一切以实现功能和快速上线项目为主,但编程经验增加,发现代码越来越难写,越来越难改。导致这样的原因是没有遵循一般性......
  • 选择排序——C语言描述
    选择排序——C语言描述目录选择排序——C语言描述0测试用例框架1定义2代码4测试用例0测试用例框架https://blog.csdn.net/m0_59469991/article/details/127137119?......
  • 数据结构学习笔记-day4
    Day4线性表的链式表示和实现:一、单链表的定义和表示:  1.单链表需要存储两部分信息,一是本身数据信息,二是下一节点的地址信息,两部分信息构成数据元素的存储映像,它包括......
  • C语言中的数据类型
    1、整型(1)short短整型(内存中占2个字节)是shortint的简写。取值范围:-32768~+32767(2Bytes)。(2)int整形(int)(内存中占4字节)取值范围:-2147483648~+2147483647(4......
  • C语言指针进阶(一)
    前言什么是指针?指针就是一个可以存储地址的变量。当我们将具体的某个对象的地址存放到某个指针变量当中时,我们可以说将某个对象的地址存放到某个指针当中,也可以说指向某个对......
  • c语言二维数组如何转成一维使用
    //直接操作a,比如a[0]得到{0,1,2,3},a[1]得到{4,5,6,7},a[2]得到{8,9,10,11}inta[3][4]={{0,1,2,3},{4,5,6,7},{8,9,10,11}};int*p1=a;......
  • Linux & 标准C语言学习 <DAY11>
    一、指针  1、什么是指针    指针是一种特殊的数据类型,使用指针可以定义指针变量,指针变量存储的是整形数据,该数据代表了内存的编号(地址),可以通过这个编号......
  • Qz学算法-数据结构篇(排序算法--基数、总结)
    基数排序1.基本介绍基数排序(radixsort)属于“分配式排序”(distributionsort),又称“桶子法”(bucketsor)或binsort,顾名思义,它是通过键值的各个位的值,将安排序的元素分......