数据结构--线性表2-2

目录

一、线性表例题: 

二、分配动态内存:

   1.动态创建一个空顺序表的算法:

 2.动态顺序表的插入算法:

3.动态顺序表的删除 

 三、线性表的链式表示和实现

 例题1:创建链表并插入26个字母

例题2:在链表中取第i个数据元素

例题3:在链表中删除一个结点

四、静态链表:


一、线性表例题: 

例题1:求两个线性表的“并”,即LA U LB= ?

算法思路:

注意集合并的含义:

LA和LB都是无序表,则从LB种取元素逐一与LA中所有元素比较,相同则不插入LA中;

Void Union(List &LA,List LB)

{//将所有在线性表Lb中但不在La中的数据元素插入到La中

        La_len=Listlength(La);

        Lb_len=Listlength(Lb);

        for(i=1;i<Le_len;i++)

        {

                GetElem(Lb,i,e);//取Lb中第i个数据元素赋给e、

                if(!LocateElem(La,e,equal))

                {

                        ListInsert(La,++La_len,e);

                }

        }

}

算法复杂度分析:LocateElem(La,e,equal) 需La_len次比较

则整个算法需O(La_len×Lb_len) 

 例题2:设正整数a的前驱为PRIOR(a),后继NEXT(a),用递归算法计算a+b。

        首先要对加法算法进行描述。不能用简单的加法语句,因为没有加法,要考虑如何用给出的两个特定函数来实现a+b?

思路:  考虑加法的定义,若用数轴来描述a+b,当a不断往"0"移动,b不断往相反方向移动的过程。当a移动到0时,b指向的位置即为a+b。

 (a可视为一减计数器,前移过程中不断递减,而b的后移则是不断加1的过程)

平常我们可以用循环来实现,但根据本题题意不能用循环,而要用递归。

设计要点有二:1.递归算法的形式化描述;2.不能无限制递归,一定要有终止条件。

结果:

int add(int a,int b);

if(a==0)   return(b);

else return (add(prior(a),next(b))); 

若a很大,b很小怎么办?

解决方法:就从小的开始进行减计数。

二、分配动态内存:

(我的C语言专栏中介绍过基础,这里跟数据结构一起编写一些)

#define LIST_INIT_SIZE	100//存储空间的初始分配量 
#define LISTINCREMENT 	10//存储空间的分配增量
Typedef struct{
ElemType *elem;		//表基址(用指针*elem) 
int 	lenght;		//表长度(表中有多少个元素) 
int 	listsize;	//当前分配的表尺寸(字节单位) 
}SqList L; 

   1.动态创建一个空顺序表的算法:

Status InitList_Sq(SqList &L)

{

        L.elem = (ElemType *)malloc(LIST_INIT_SIZE * sizeof(ElemType));

        if(!L.elem) exit(OVERFLOW);//分配失败,结束程序

        L.length=0;                                //暂无元素放入,空表

        L.listsize = LIST_INIT_SIZE;        //表尺寸=初始分配量

        Return       OK;

}//InitList_Sq

 2.动态顺序表的插入算法:

Status ListInsert_Sq(SqList &L,int i,ElemType e)

{//在顺序线性表中第i个位置之前插入新的元素e

    if(i<1||i>L.length+1) return ERROR;//检验i值得合法性

    if(L.length>=L.listsize)//若表长超过表尺寸则要增加尺寸

        {

                newbase = (ElemType*)realloc(L.elem,(L.listsize+LISTINCREMENT)*sizeof(ElemType));//realloc(*p,newsize)函数的意思是:新开一片大小为newsize的连续空间,并把以*p为首地址的原空间数据都拷贝进去。

        if(newbase = NULL) exit(OVERFLOW);        //分配失败则退出报错

        L.elem = newbase;                        //重置新基址

        L.listsize = L.listsize +LISTINCREMENT;}//增加表尺寸

        q=&L.elem[i-1];                //q为插入位置。这里没有头结点的情况

        for(p=L.elem[L.length-1];p>=q;--p)  *(p+1)=*p;

//插入位置及之后的元素统统后移,p为元素位置

        *q = e;        //插入e

        ++L.length;        //增加1个数据元素,则表长+1

        return OK;

        }//ListInsert_Sq

}

3.动态顺序表的删除 

Status ListDelete_Sq(SqList &L,int i,ElemType &e) 
{//在顺序表L中删除第i个元素,用e返回其值 
	if(i<1||L.length) return ERROR;//i值不合法,返回 
	p=&L.elem[i-1];			//p是被删除元素的位置 
	e=*p;					//被删除元素的值赋给e 
	q=L.elem+L.length-1;	//q是表尾的位置 
	for(++p;p<=q;p++)		 
	*(p-1)=*p;				//待删除元素后面的统统前移
	--L.length;				//表长-1 
	return ok;
}//ListDelete_Sq 

 三、线性表的链式表示和实现

1、链表的表示

(1)链式存储结构特点:

其结点在存储器总的位置是随意的,即逻辑上相邻的数据元素在物理上不一定相邻。

设计效率:牺牲空间效率换取时间效率

头指针:是指向链表中第一个结点(或为头结点、或为首结点)的指针;

头结点:是在链表的首元结点之前附设的一个结点;数据域内只放空表标志和表长等信息,它不计入表长度;

首元结点:是指链表中存储线性表第一个数据元素a1的结点。 

Typedef struct Lnode{
ElemType  data;		//数据域 
struct Lnode *next;	//指针域 
}Lnode,*LinkList; 	//*LinkList为Lnode类型的指针 

 例题1:创建链表并插入26个字母

#include <stdio.h>
#include <stdlib.h>
typedef struct node{
	char data;
	struct node *next;
}node;

node *p,*q,*head;
int n;
int m=sizeof(node);

void build()		//字母链表的生成。要一个个慢慢链入 
{
	int i;
	head=(node*)malloc(m);// 
	p=head;
	for(i=1;i<26;i++)//因尾结点要特殊处理,故i≠26 
	{
		p->data=i+'a'-1;//第一个结点值为字符a 
		p->next=(node*)malloc(m);//为后继结点“挖坑” 
		p=p->next;	//让指针变量p指向后一个结点 
	}
	p->data=i+'a'-1;//最后一个元素要单独处理 
	p->next=NULL;	//单链表尾结点的指针域要置空 
 } 
 
void display()//字母链表的输出 
{
	p=head;
	while(p)//当指针不空时循环(仅限于无头结点的情况) 
	{
		printf("%c",p->data);
		p=p->next;
	}
 } 
 
 int main(void)
 {
 	build();
 	display();
  } 

例题2:在链表中取第i个数据元素


Status GetElem_L(Linklist L,int i,ElemType &e)
{//L为带头结点的单链表的头指针
 //当第i个元素存在时,其值赋给e并返回OK,否则返回error 
	p=L->next;j=1;
//初始化,p指向第一个结点,j为计数器 
	while(p&&j<i)
	{
//顺指针向后查找,直到p指向第i个元素或p为空 
		p=p->next;++j;
	}
//第i个元素不存在 
	if(!p||j>i) return ERROR;
	e=p->data;//取第i个元素 
	return ok;
}GetElem_L

例题3:在链表中删除一个结点

Status ListDelete_L(Linklist &L,int i,ElemType e)
{//在带头结点的单链表L中,删除第i个元素,并由e返回其值 
	p=L;j=0;
	while(p->next&&j<i-1)
	{//寻找第i个结点,并令p指向其前驱 
		p=p->next;++j;
	 } 
	 if(!(p->next)p||j>i-1)	return ERROR;//删除不合理位置 
	 q=p->next;
	 p->next=q->next;//删除并释放结点 
	 e=q->data;free(q);
	 return ok;
 } 

四、静态链表:

        定义一个结构型数组(每个元素都含有数据域指示域),就可以完全描述链表,指示域就相当于动态链表的指针,称为游标

静态链表的类型定义如下:

#define MAXSIZE 1000 //预分配最大的元素个数(连续空间)

typedef  struct {

        ElemType  data;        //数据域

        int              cur;          //指示域

}component,SLinkList[MAXSIZE];        //这是一维结构型数组

例题4:利用静态链表存储s=(zhao,qian,sun,li,zhou,wu)。

其原理跟动态差不多,写法类似,知识不需要在使用指针。 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/59463.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

MGRE综合

实验 一、实验思路 1.先按照上图配置IP地址及环回 2.写缺省使公网可通 3.让R1、R4、R5每台路由器均成为中心站点形成全连网状结构拓扑 4.让R1成为中心站点R2R3为分支站点 5.分区域宣告ospf之后更改ospf在虚拟接口Tunnel工作方式为broadcast及让R1 当选DR 二、上虚拟机操作…

【已解决】vagrant up下载box速度太慢的解决方法

一、问题背景 本菜鸟在学习雷神(尚硅谷雷丰阳)的这个教程Java项目《谷粒商城》Java架构师 | 微服务 | 大型电商项目的时候&#xff0c;按照视频教程的步骤&#xff0c;正准备用Vagrant工具给VirtualBox安装并启动Centos7的Linux操作系统&#xff0c;当在Windows命令提示符窗体…

把网站改为HTTPS访问方法

HTTPS是使用TSL/SSL加密超文本传输协议的扩展&#xff0c;用于跨网络的安全传输。网站更改为HTTPS&#xff0c;直接在网站形象上可以得到提升&#xff0c;更重要的是您的网站肯定会在排名和提升方面受益。机密信息的交换需要受到保护&#xff0c;以阻止未经授权的访问。 加密&a…

Mock.js的基本使用方法

官网网址&#xff1a;Mock.js (mockjs.com) 当前端工程师需要独立于后端并行开发时&#xff0c;后端接口还没有完成&#xff0c;那么前端怎么获取数据&#xff1f; 这时可以考虑前端搭建web server自己模拟假数据&#xff0c;这里我们选第三方库mockjs用来生成随机数据&#xf…

Emacs之远程开发C++配置: emacs + tramp + clangd(一百二十六)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 人生格言&#xff1a; 人生…

动手学深度学习(二)线性神经网络

推荐课程&#xff1a;跟李沐学AI的个人空间-跟李沐学AI个人主页-哔哩哔哩视频 回归任务是指对连续变量进行预测的任务。 一、线性回归 线性回归模型是一种常用的统计学习方法&#xff0c;用于分析自变量与因变量之间的关系。它通过建立一个关于自变量和因变量的线性方程&…

Matlab的信号频谱分析——FFT变换

Matlab的信号频谱分析——FFT变换 Matlab的信号频谱分析 FFT是离散傅立叶变换的快速算法&#xff0c;可以将一个时域信号变换到频域。 有些信号在时域上是很难看出什么特征的。但是如果变换到频域之后&#xff0c;就很容易看出特征了。 这就是很多信号分析采用FFT变换的原因…

企业微信小程序在调用wx.qy.login时返回错误信息qy.login:fail

原因是大概是绑定了多个企业但是在开发者工具中没有选择正确的企业 解决方法&#xff1a; 重新选择企业后即可成功获取code

媒介易讲解体育冠军助力品牌解锁市场营销新玩法

在当今竞争激烈的市场中&#xff0c;品牌推广成为企业取得商业成功的重要一环。然而&#xff0c;随着传统市场推广方式的日益饱和&#xff0c;企业急需创新的市场营销策略来吸引消费者的关注和认可。在这样的背景下&#xff0c;体育冠军助力品牌成为了一种备受瞩目的市场营销新…

Android Jetpack

Jetpack 是一个由多个库组成的套件&#xff0c;可帮助开发者遵循最佳实践、减少样板代码并编写可在各种 Android 版本和设备中一致运行的代码&#xff0c;让开发者可将精力集中于真正重要的编码工作。 1.基础组件 &#xff08;1&#xff09;AppCompat&#xff1a;使得支持较低…

SharpShooter Gauges.Professional Crack

SharpShooter Gauges.Professional Crack 将真实仪器硬件的外观添加到.NET应用程序中。 SharpShooter Gauges旨在创建和使用任何行业特定的KPI、计算机辅助培训系统、SCADA系统、数字仪表板和任何其他用于显示和监控关键任务数据的应用程序。为了实现所有这些目的&#xff0c;一…

概率论与数理统计:第一章:随机事件及其概率

文章目录 概率论Ch1. 随机事件及其概率1.基本概念(1)随机试验、随机事件、样本空间(2)事件的关系和运算①定义&#xff1a;互斥(互不相容)、对立②运算法则&#xff1a;德摩根率 (3)概率的定义(4)概率的性质(5)概率计算排列组合 2.等可能概型1.古典概型 (离散)2.几何概型 (连续…

glut太阳系源码修改和对cpu占用观察

#include <GL/glut.h> static int day 100; // day 的变化&#xff1a;从 0 到 359 void myDisplay(void) {//glEnable(GL_DEPTH_TEST);glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);glMatrixMode(GL_PROJECTION);glLoadIdentity();gluPerspective(75, 1, 1, 40…

Docker-Compose编排与部署(lnmp实例)

第四阶段 时 间&#xff1a;2023年8月3日 参加人&#xff1a;全班人员 内 容&#xff1a; Docker-Compose编排与部署 目录 一、Docker Compose &#xff08;一&#xff09;概述 &#xff08;二&#xff09;Compose适用于所有环境&#xff1a; &#xff08;三&#xf…

Java阶段五Day16

Java阶段五Day16 文章目录 Java阶段五Day16问题解析启动servlet冲突问题nacos注册中心用户信息验证失败前端效果不对前端请求到后台服务的流转过程 远程dubbo调用业务需求dubbo配置xml配置domain层代码 补充远程调用 师傅详情接口抽象开发WorkderServerControllerWorkerServerS…

51单片机学习-AT24C02数据存储秒表(定时器扫描按键数码管)

首先编写I2C模块&#xff0c;根据下面的原理图进行位声明&#xff1a; sbit I2C_SCL P2^1; sbit I2C_SDA P2^0;再根据下面的时序结构图编写函数&#xff1a; /*** brief I2C开始* param 无* retval 无*/ void I2C_Start(void) {I2C_SDA 1; I2C_SCL 1; I2C_SDA 0;I2C_S…

redis原理 6:小道消息 —— PubSub

前面我们讲了 Redis 消息队列的使用方法&#xff0c;但是没有提到 Redis 消息队列的不足之处&#xff0c;那就是它不支持消息的多播机制。 img 消息多播 消息多播允许生产者生产一次消息&#xff0c;中间件负责将消息复制到多个消息队列&#xff0c;每个消息队列由相应的消费组…

【Leetcode刷题】位运算

本篇文章为 LeetCode 位运算模块的刷题笔记&#xff0c;仅供参考。 位运算的常用性质如下&#xff1a; a ^ a 0 a ^ 0 a a ^ 0xFFFFFFFF ~a目录 一. 基本位运算Leetcode29.两数相除Leetcode89.格雷编码 二. 位运算的性质Leetcode136.只出现一次的数字Leetcode137.只出现一…

好用的数据库管理软件之idea(idea也有数据库???)

1.建立maven项目&#xff08;maven项目添加依赖&#xff0c;对于后期连接数据库很方便&#xff09; 2.连接数据库。。。 这里一定注意端口号&#xff0c;不要搞错了 和上一张图片不一样哦 3.数据库测试代码。。。 然后你就可以在这里边写MySQL代码了&#xff0c;这个工具对于新…

RunnerGo条件控制器使用方法

在做性能测试时我们需要根据业务需求、业务场景来配置测试脚本&#xff0c;举个例子&#xff1a;在登录注册场景中&#xff0c;可能会有账号密码全部正确、账号格式错误、密码错误等多种情况&#xff0c;这里的“登录/注册”事件可以视为一个场景。一个真实业务中的场景&#x…