数据结构习题(顺序表)
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--;//表长度变化

}

}

}

相关内容

热门资讯

更近一步!王欣瑜2-0完胜13... 北京时间1月24日,澳网女单第三轮继续进行。中国选手王欣瑜直落两盘,以总分2-0(7-5 6-4)击...
金桥信息2022年员工持股计划... 上证报中国证券网讯 金桥信息1月23日晚发布公告,公司2022年员工持股计划(以下简称“本员工持股计...
特朗普威胁欧洲:敢抛售美国资产... 近来,围绕“夺岛”风波和关税威胁等问题,美欧矛盾不断。抛售美国资产被视为欧洲可能采取的反制措施之一。...
商道创投网·会员动态|术理创新... 《商道创投网》2026年1月24日从官方获悉:术理创新近日完成了由国家中小企业发展基金、东方富海和老...
50万元以上电诈案件降低29%... 1月23日,重庆市公安局举办2025年度公安基层技术革新比武暨改革创新大赛决赛,“山城金盾——涉诈资...
原创 报... 作品声明:内容取材于网络 大家好,我是闻叔。近期国际政坛最具冲击力的新闻,莫过于特朗普对法国的雷...
各地多措并举优化消费环境 让消... 商场环境如何保持新鲜感,实体店购物后退换是否方便,预订服务、预付费用会不会有“坑”……消费环境优劣,...
马斯克SpaceX背后的她:现... 鹭羽 发自 凹非寺 量子位 | 公众号 QbitAI 2026年全球资本市场的头号悬念,非Space...
原创 土... 前两天的节目里,我们和大家讨论了人民币升值的话题。今年以来,人民币对美元的汇率持续走强,截至今天,1...
纳电商业化加速 记者 郑晨烨 1月22日,宁德时代(300750.SZ)发布新的天行轻商系列动力电池。该系列电池涵盖...
新华读报|马斯克称“擎天柱”机... 《参考消息》1月24日综合法新社、路透社报道《马斯克称“擎天柱”机器人明年开售》。 埃隆·马斯克22...
新发现:失落的构造板块可能让加... 想象一下,你正在加州的阳光下悠闲地享受生活,突然听说在你脚下的地壳深处,潜藏着一块失落的构造板块碎片...
马斯克达沃斯预言「后人类时代」... 新智元报道 编辑:定慧 【新智元导读】刚刚,达沃斯论坛迎来两场震撼全场的演讲。世界首富马斯克预言:...
行业低谷夯实根基 新五丰养殖规... 本报讯 (记者何文英)2025年四季度,中国生猪行业再度深陷低迷期——猪价处于低位、供需失衡,“卖一...
原创 油... 2026年1月24日蛋价:蛋价“火箭”上涨,破3入4! 近日,国内鸡蛋市场,蛋价迎来了“春天”,受春...
原创 得... 特朗普上台不久,就将目光锁定在格陵兰岛——对他而言,这不仅仅是一块冰封的土地,而是一枚战略棋子,足以...
面临裁员无可奈何,亚马逊员工内... 来源:市场资讯 (来源:IT之家) IT之家 1 月 24 日消息,据《商业内幕》(Business...
2026投资指南,嘉实基金投策... 来源:时代周报-时代在线 2026年是“十五五”规划的开局之年,也是布局中国经济高质量发展红利的关键...
2026年首家!又一具身智能企... 1月23日,记者获悉,星海图(北京)人工智能科技有限公司已于2026年1月完成工商变更,正式更名为“...
原创 历... 在历经千年战争的漫长历史中,有一种特殊的战斗形式至今依旧困扰着军事指挥官们,那就是攻城战。从古至今,...