数据结构与算法——探索线性表

目录

线性表的定义

顺序表

顺序表的基本操作

总结


线性表的定义

线性表的定义: 用数据元素的有限序列表示

数据结构与算法——探索线性表

 

从上图我们可以看出来,线性表主要有以下几个特点:

  1. 有且仅有一个开始结点(该结点只有一个直接后继结点,没有直接前趋结点)
  2. 有且仅有一个终端结点(该结点只有一个直接前趋结点,没有直接后继结点)
  3. 其余节点有且仅有一个直接前趋和一个直接后继
  4. 元素及元素之间的关系为线性

例如:( A, B, C, D, …… , Z)
数据元素都是数字; 元素间关系是线性

同一线性表中的元素必定具有相同特性

顺序表

线性表采用顺序存储的方式存储就称之为顺序表。

顺序表是将表中的结点依次存放在计算机内存中一组地址连续的存储单元中。

计算机内存中一组地址连续的存储单元依次存储线性表的数据元素。

顺序表一般的数据结构 如下:

数据结构与算法——探索线性表

数组的长度大于等于当前线性表的长度

代码定义:

#define MAXSIZE 100  //存放容量
typedef int datatype;
typedef struct{
  datatype a[MAXSIZE];
  int size; //实际大小
}sequence_list; //顺序表类型

sequence_list slt,*pslt;

访问下标为 i 的元素:slt.a[i] 或pslt->a[i]
线性表的长度:slt.size 或 pslt->size

顺序表的基本操作

顺序表的初始化---置空表

void init(sequence_list slt)
{
  slt->size=0;
}

遍历运算

void display(sequence_list slt)
{
  int i;
  if(!slt.size) 
    printf("\n顺序表是空的!");
  else
    for(i=0;i<slt.size;i++) 
      printf("%5d",slt.a[i]);
}

插入运算

在顺序表的第 i( 0≤i≤n) 个位置上插入一个值为 x 的结点

从an开始逐个向前,每个元素向后移一格

数据结构与算法——探索线性表

 

void insert(sequence_list slt,datatype x,int position)
{ 
 int i;
 if(slt->size==MAXSIZE) {
   printf("\n顺序表是满的!没法插入!");
   exit(1);
 }
 if(position<0||position>slt->size) {
   printf("\n指定的插入位置不存在!");
   exit(1);
 }
 for(i=slt->size;i>position;i--) 
   slt->a[i]=slt->a[i−1];
 slt->a[position]=x;
 slt->size++;
}

删除运算

删除顺序表的第 i( 0≤i≤n-1) 个位置上的结点

数据结构与算法——探索线性表

 

void dele(sequence_list slt,int position)
{
  int i;
  if(slt->size==0) {
    printf("\n顺序表是空的!");
    exit(1);
  }
  if(position<0||position>=slt->size) {
    printf("\n指定的删除位置不存在!");
    exit(1);
  }
  for(i=position;i<slt->size-1;i++) 
    slt->a[i]=slt->a[i+1];
  slt->size--;
} 

在顺序表后部进行插入操作

void append(sequence_list slt,datatype x)
{ 
  if(slt->size==MAXSIZE) {
    printf("顺序表是满的!");
    exit(1);
  }
  slt->a[slt->size]=x;
  slt->size=slt->size+1;
}

判断顺序表是否为空

int empty(sequence_list slt)
{
	return (slt.size==0 ? 1:0);
}

查找顺序表中值为x的结点位置

int find(sequence_list slt,datatype x)
{ 
  int i=0;
  while( i < slt.size && slt.a[i] != x )
    i++;
  return(i < slt.size ?  i : −1);
}

取得顺序表中第i个位置上结点的值

datatype get(sequence_list slt, int i)
{
  if(i<0||i>=slt.size) {
    printf("\n指定位置的结点不存在!");
    exit(1);
  }
  else
    return slt.a[i];
}

接下来给大家举一个简单点的例子,将顺序表的数据颠倒过来

数据结构与算法——探索线性表

 

有如上图所示的顺序表,现在我们将数据颠倒成下面这样

数据结构与算法——探索线性表

 

代码实现如下:

void verge(sequence_list *slt)
{ 
  int i,j,temp;
  i=0;j=slt->size-1;
  while(i<j) {
    temp=slt->a[i];
    slt->a[i]=slt->a[j];
    slt->a[j]=temp;
    i++;j--;
  }
}

实际使用中,线性表的用途很广泛,同一类型的数据都可以通过这种方式存储。

总结

  • 线性表中数据元素的类型可以为简单类型,也可以为复杂类型。
  • 许多实际应用问题所涉的基本操作有很大相似性,不应为每个具体应用单独编写一个程序。
  • 从具体应用中抽象出共性的逻辑结构和基本操作(抽象数据类型),然后实现其存储结构和基本操作。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
武汉理工大学的数据结构与算法实验包括线性表的应用、栈的应用、树的应用、无向图的应用、有向图的应用、查找与排序、哈夫曼编码等内容。这些实验旨在帮助学生掌握数据结构的设计和应用,包括图的存储结构和创建方法、图的遍历方法、迪杰斯特拉算法、最小生成树的概念、普里姆算法等。此外,还有一个名为"简易计算器程序"的实验项目,项目内容是编写程序来模拟简单运算器的工作,实现对缀表达式的计算。希望通过这些实验,学生能够加深对数据结构算法的理解,并提升编程能力。123 #### 引用[.reference_title] - *1* *3* [武汉理工大学数据结构课内实验](https://blog.csdn.net/mo_zhe/article/details/112733427)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] - *2* [武汉理工大学数据结构综合实验——图与景区信息管理系统实践](https://blog.csdn.net/mo_zhe/article/details/112771599)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值