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

}

}

}

相关内容

热门资讯

不良率上升倒逼防线前移 银行收... 银行正在给个人信贷风控“上强度”。上海证券报记者近期自业内多方了解到,不少银行零售信贷业务从审批权限...
自媒体新手如何快速涨粉?这5个... 自媒体新手如何快速涨粉?这5个技巧让你少走弯路! 嗨,我是小融。 最近很多刚入门自媒体的朋友问我,怎...
乌兰察布市财政局关于黄金领域非... 乌兰察布市财政局关于黄金领域 非法金融活动风险提示 近期,黄金价格波动频繁,市场热度持续攀升,各类假...
一只鸡蛋架“直发”俄罗斯 无锡... (来源:无锡新传媒) 转自:无锡新传媒 一只3D打印塑料鸡蛋架,成为无锡国际邮件互换局正式开通运营后...
武汉楼市开启红五月 新房成交量... 原标题:武汉楼市开启红五月 数据爆表,新房成交量较去年同期翻番 武汉城建未来中心项目营销中心现场来...
一家精神病院竟现身A股公司前十... 5月8日,有投资者发现,盛通股份前十大股东名单中,竟出现了一家精神病院的身影。这家精神病院全称为“上...
真的老了!哈登心魔难除 骑士还... 哈登又拉胯了。 刚刚过去的两场东部半决赛,骑士都输的相当狼狈,而哈登的发挥更是灾难级的。 半决赛G1...
精神病院通报成上市公司前十大股... 近日,上市公司盛通股份发布一季报,披露了前十大股东名单。其中,一家名为“上饶市广丰区十五岭山精神病医...
天溯计量发布年报 上市首年检测... 转自:中国经营网 文 近日,计量检测机构天溯计量(301449.SZ)发布了2025年年度报告。年...
原创 全... 美伊真要停火了? 一页纸协议让全球油价闪崩! 就在今天,全球市场被一条消息炸开了锅。美国白宫觉得,他...
百信银行业绩:26Q1净利润大... 4月底,中信百信银行股份有限公司(下称“百信银行”)2025年财报及2026年一季度报接连披露—— ...
美光科技股价单周飙升38% 市... 【CNMO科技消息】受全球内存芯片短缺影响,美光科技股价本周大幅上涨。截至周五收盘,美光股价报746...
江西一精神病院炒股,炒成上市公... 近日,上市公司盛通股份(002599.SZ)发布一季报,披露了前十大股东名单,其中一家名为“上饶市广...
专访中国太保副总裁俞斌:从“+... 拥抱AI(人工智能),不再是保险行业的“选择题”,而是关乎企业生存与发展的“必答题”,更是企业决胜未...
多平台优化算法:美团取消超时扣... 图片来源:界面图库 5月8日,网信中国发布消息称,生活服务类平台算法治理已取得初步成效,美团、淘宝、...
原创 2... 2025年,国内系统重要性银行名单正式公布。这是我国金融体系的核心支柱,一共21家银行入选,它们是维...
东海县供销总社:“供销+龙头企... 近日,东海县供销合作总社鼎味泰直营店正式开业。作为东海县供销系统打造的新型社企便民服务网点,该门店的...
原创 阿... 深夜,一家零食店铺的客服后台弹出一条消息:“我上次买的芒果干,这次想换个不那么酸的口味,再帮我推荐几...
和平湾全新项目前瞻 负公摊、唯... 在沈阳,如果想在主城核心区域找一块容积率低于1.5的住宅用地,难度有多大? 过去三年,沈阳主城核心区...
精神病院与国际投行高盛同在 盛... 近日,盛通股份(002599.SZ)发布一季报,其前十大股东名单中,第九位为“上饶市广丰区十五岭山精...