数据结构习题(顺序表)
admin
2024-02-08 09:22:20
0

用顺序表实现下列函数

顺序表中包含两个内容

data

顺序标长度

(1)从顺序表中删除具有最小值的元素并由函数值返回被删的元素,空出的位置由最后一个元素填充,若顺序表为空,则显示出错信息并退出运行

Elemtype delete(SqList *L)//函数返回值类型未知,所以用这个

//传入参数

{

int p=0;

Elemtype min=List->data[p];//假设最小值为刚开始

if(List->Length==0)

{

cout<<"线性标为空"<

return false;

}

for(int i=1;iLength;i++)

{
if(List->data[i]<=min)

{

min=List->data[i];

p=i;//记录下位置

}

}

List->data[p]=List->data[List->Length-1];//填充空余的位置用记录的位置

List->Length--;

return min;//返回最小值

}

(2)从顺序表中删除第i个元素并由函数返回被删元素的值,如果i不合理或者顺序表为空则显示出错信息并退出

Elemtype deletei(SqList L,int i)//传入参数,线性表和第i个位置

{

if(i<0||i>=L->Length||L->Length==0)//判断条件

{

cout<<"请检查i的输入"<

exit(1);

}

Elemtype t=L->data[i-1];//记录第i个位置的元素

for(int j=i-1;j

{

L->data[j]=L->data[j+1];

};

L->Length--;//长度要变化

return t;//返回被删除的第i个元素

}

(3)向顺序表中第i个位置插入一个新的元素x,如果i不合理则显示出错信息并退出运行;

int insert (SqList &L,int i,int x)

{

if(i<0||i>L->Length+1||L->Length>=MaxSize)//条件判断

{

cout<<"请检查输入“<

exit(1);//退出程序

}

L->data[i-1]=x;//插入位置赋值;

for(int j=L->Length;j>=i;j--)//其他位置移动

{

L->data[j]=L->data[j-1];

}

L->Length++;//长度加1

return true;

}

(4)从顺序表中删除具有给定值x的所有元素;

template

void deletex(SqList&L, T x)//传入参数

{

for(int i=0;iLength;i++)

{

if(L->data[i]==x)//找到的情况

{

for(int j=i;j

{

a[j]=a[j+1];

}

L->Length--;//长度变化;

}

return 0;

}

(5)从无序顺序表中删除其值在给定值s和t之间(要求s小于t)的所有元素,如果s或者t不合理或者顺序表为空则显示出错信息并退出

算法思路:

从前向后扫描顺序表a,用k记录下元素值在s到t之间元素的个数。对于当前扫描的元素,若其值不在s到t之间,则向前移k个位置。

(这个理解起来有点抽象但是画个图就可以很轻松的写出来了)

template

bool deletest(SqList&L, Elemtype s,Elemtype t)

{

int k=0;//记录下满足条件的元素个数

if(s>=t||L.Length==0)//空表且不满足的情况判断

{

return false;

}

for(int i=0;i

{

if(L.data[i]>=s&&L.data[i]<=t)//符合的条件判断

{

k++;

}

else

{

data[i-k]=data[i];//向前移动k个位置

}

}L.Length-=k;//表的长度发生变化

}

(6)从有序顺序表中删除其值在给定值s和t之间(要求s小于t)的所有元素,如果s或者t不合理或者顺序表为空则显示出错信息并退出;

因为顺序表是有序的所以我们只需要找到需要删除的第一个元素和需要删除的最后一个元素最后整段删除就行了;

template //类模板

booL deletest2 (SqList&L,ELemtype s,Elemtype t)//传入参数

{

if(s>=t||L.Length==0)//条件判断

{

cout<<"请检查输入"<

return false;

}

int i=0;//记录小于大于s的第一个数

while(i {

i++;

]

int j=i;

while(j

j++;//寻找大于t的第一个元素

for(;j

{

a[i]=a[j];//填补被删元素

}

L.Length=i;//说实话在这里我也有点看不懂

}

(7)将两个顺序表合并为一个新的顺序表并由函数返回结果顺序表

算法思想:

对于有序的顺序表来说,可以新建立一个顺序表,将传入的两个顺序表从头节点开始比较,不断取下两个顺序表中表头较小的结点,存到新的顺序表中
第二步:看哪个顺序表有剩余,将剩余结点加到新的顺序表后面

template

 SeqList merge(SqList a,SqList b,SqList &c)//传入线性表  a,b

{

if(a.Length+b.Length>c.MaxSize)//不符合的情况

return false;

int i=0,j=0,k=0;//分别记录三者下标

while(i

{

if(a.data[i]<=b.data[i]

{

c.data[k++]=a.data[i++];//自增,先传递数值然后对下标进行移动

}

else

c.data[k++]]=b.data[j++];

}

}

while(i

{

c.data[k++]=a.data[i++];

}

while(i

{

c.data[k++]=b.data[j++];

}

c.Length=k;//记录长度;

return false;

}

(8)从有序顺序表中删除所有值重复的元素,使得表中的元素值不同;

void deleteqc(SqList &L);//传入顺序表

{

for(int i=0;i

{

if(L.data[i]==L.data[i+1])//元素重复

{

for(int m=i+1;m

{

L.data[m]=data[m+1];

}//删除操作;

L.Length--;//表长度变化

}

}

}

相关内容

热门资讯

消息称百度旗下昆仑芯瞄准500... 6 月 29 日消息,据《The Information》昨日援引知情人士消息,百度旗下 AI 芯片...
打造夏日消费新场景 第35届北... 北京商报讯(记者 翟枫瑞)6月29日消息,第35届北京国际燕京啤酒文化节新闻发布会在京举行。本届啤酒...
社保基金持仓数据出炉,一季度增... 最近各大上市公司一季度财报都公开了,咱们国家社保基金的持仓数据也全部曝光。目前社保拿着比亚迪价值44...
36氪首发 | 海思、中兴团队... 作者 | 乔钰杰 编辑 | 袁斯来 硬氪获悉,广州宸思通讯科技有限公司(以下简称“宸思科技”)近日完...
两天蒸发47亿市值!一纸税务通... 一纸税务通知书,能让一家百亿龙头两天蒸发47亿市值。 6月22日,北大荒(600598.SH)公告称...
SK海力士将投资1100万亿韩... SK集团会长崔泰源6月29日在韩国“三大重大计划”发布会上宣布,公司将投资1100万亿韩元扩大半导体...
两只A股,终止上市! 两家A股公司,即将摘牌。 6月29日,退市沪科(600608.SH)公告称,上海证券交易所将在202...
原创 M... 一家成立近十年的自动驾驶公司,在IPO时吸引了14家基石投资者认购近一半的发行股份,其中不乏奔驰、比...
基金忠言|国寿安保滤镜碎,三年... 图片来源:视觉中国 蓝鲸新闻6月29日讯(记者 祁和忠)保险系基金公司国寿安保总经理换人了。 6月2...
三星电机计划加码玻璃基板!相关... 6月29日,玻璃基板概念股午后有所回升, 华工科技(000988.SZ)逼近涨停, 彩虹股份(600...
拉萨海关持续壮大外贸经营主体 ...   新华网拉萨6月28日电(记者蒋梦辰)近日,记者从拉萨海关获悉,今年前5个月,西藏有进出口实绩的外...
机构:二季报临近,医药生物板块... 6月29日,华源证券发布了一篇医药生物行业的研究报告,报告指出,业绩期临近,产业链景气度有望再次迎来...
每日收评科创50放量涨超4.5... 财联社6月29日讯,三大指数全线收红,创业板指探底回升,科创50指数大涨4.61%。沪深两市成交额3...
6月多地土拍结构性升温:深圳单... 进入2026年6月,不少城市核心区地块集中诞生高溢价宗地,热度突出的城市包含深圳、杭州、长沙。 其中...
业绩炸裂!盛达资源半年预盈3.... 6月29日,贵金属矿山龙头盛达资源(000603.SZ)发布 2026 年半年度业绩预告,上半年业绩...
A股午后拉升三大股指收涨:半导... A股三大股指6月29日开盘涨跌互现。早盘沪强深弱,创指一度跌超2%。半导体午后拉升,带动两市上涨,沪...
原创 空... 前言 大家好,我是老金。 这几天,两幅极度割裂的画面放在一起,把我看笑了。 一边是在持续的热浪下,欧...
澳大利亚审慎监管局拟放宽银行风... 澳大利亚审慎监管局(APRA)6月29日就修改 银行信用风险资本设定公开征求意见,旨在加大信贷投放以...
全民炒股,急踩刹车!韩国股市突... 屈红燕/证券时报网 全民狂欢、交易高度拥挤、杠杆资金猛增、新入市投资者表现激进、大型IPO吸金等现象...