考研《数据结构》线性表—顺序表练习题

news2024/11/24 1:16:04

2.设计一个高效算法,将顺序表L的所有元素逆置,要求算法的空间复杂度为0(1)。

思路:扫描顺序表L的前半部分元素,对于元素L.data[i]与L.data[len-1-i]对换。

#include<iostream>
using namespace std;
const int maxn=100;
int len;
//定义顺序表
typedef struct
{
    int data[maxn];
    int length;
}Sqlist;
//实现逆置
void rev(Sqlist &l)//注意这里是引用传递
{

    int tem;
    for(int i=0;i<len/2;i++)
    {
        tem=l.data[i];
        l.data[i]=l.data[len-1-i];
        l.data[len-1-i]=tem;
    }
}
int main()
{
    Sqlist lis;
    cin>>len;//输入顺序表的长度
    for(int i=0;i<len;i++)
    {
        cin>>lis.data[i];
    }
    rev(lis);
    for(int i=0;i<len;i++)
        cout<<lis.data[i]<<" ";
    return 0;
}

运行结果:

3.对长度为n的顺序表L 编写一个时间复杂度为0(n)、空间复杂度为0(1)的算法,该算法删除线性表中所有值为x的数据元素

思路:用k记录顺序表L中不等于x的元素个数(即需要保存的元素个数),扫描时将不等于X的元素移动到下标L的位置,并更新k值。

#include<iostream>
using namespace std;
const int maxn=100;
int len;
//定义了一个顺序表
typedef struct
{
    int data[maxn];
    int length;
}Sqlist;
//实现删除值为x的元素
void del_x(Sqlist &l,int x)
{
    int k;
    for(int i=0;i<len;i++)
    {
        if(l.data[i]!=x)//用掷不为x的元素覆盖顺序表,k表示顺序表现在的长度
        {
            l.data[k]=l.data[i];
            k++;
        }
    }
    len=k;
}
int main()
{
    Sqlist lis;
    cin>>len;//输入顺序表的长度
    for(int i=0;i<len;i++)
    {
        cin>>lis.data[i];
    }
    del_x(lis,3);//假设删除值为3的元素
    for(int i=0;i<len;i++)
        cout<<lis.data[i]<<" ";
    return 0;
}

运行结果:

 

 4.从有序顺序表中删除其值在给定值s与t之间(包含s和t,要求s<t)的所有元素,若s或t不合理,或顺序表为空,则显示出错信息并退出运行。

思路:本题与上一题存在区别。因为是有序表,所以删除的元素必然是相连的整体。先寻找值大于等于s的第一个元素(第一个删除的元素),然后寻找值大于t的第一个元素(最后一个删除的元素的下一个元素),要将这段元素删除,只需直接将后面的元素前移。

#include<iostream>
using namespace std;
const int maxn=100;
int len;
typedef struct
{
    int data[maxn];
    int length;
}Sqlist;
bool del_s_t(Sqlist &l,int s,int t)
{
    int i,j;
    if(len==0||s>=t) return 0;//表为空,或者s、t不合法,则返回false
    for(i=0;i<len&&l.data[i]<s;i++);//找到第一个大于s的元素(删除的第一个元素)
    if(i>=len) return false;//所有元素都小于s,返回false
    for(j=i;j<len&&l.data[j]<=t;j++);//找到第一个大于t的元素(删除的最后一个元素的下一个)
    for(;j<len;i++,j++)
        l.data[i]=l.data[j];//用后面的元素覆盖上去
    l.length=i;
    len=l.length;
    return true;
}
int main()
{
    Sqlist lis;
    cin>>len;//输入顺序表的长度
    for(int i=0;i<len;i++)
    {
        cin>>lis.data[i];
    }
    del_s_t(lis,3,6);
    for(int i=0;i<len;i++)
        cout<<lis.data[i]<<" ";
    return 0;
}

运行结果:

 

5.从顺序表中删除其值在给定值s与t之间(包含s和t,要求s<t)的所有元素,若s或t不合理,或顺序表为空,则显示出错信息并退出运行。

 思路:用k记录下元素值在s至t之间元素的个数,对于当前扫描的元素,若其值不在s到t之间,则前移k个位置;否则执行k++。

#include<iostream>
using namespace std;
const int maxn=100;
int len;
typedef struct
{
    int data[maxn];
    int length;
}Sqlist;
bool del_s_t(Sqlist &l,int s,int t)
{
    int k;
    l.length=len;
    if(len==0||s>=t) return 0;//表为空,或者s、t不合法,则返回false
    for(int i=0;i<len;i++)//遍历一遍顺序表
    {
        if(l.data[i]>=s&&l.data[i]<=t) k++;//记录要删除元素的个数
        else
            l.data[i-k]=l.data[i];//当前元素前移k个位置
    }
    l.length-=k;
    len=l.length;
    return true;
}
int main()
{
    Sqlist lis;
    cin>>len;//输入顺序表的长度
    for(int i=0;i<len;i++)
    {
        cin>>lis.data[i];
    }
    del_s_t(lis,3,6);
    for(int i=0;i<len;i++)
        cout<<lis.data[i]<<" ";
    return 0;
}

 运行结果:

 6.从有序顺序表中删除所有其值重复的元素,使表中所有元素的值均不同。

思路:注意是有序顺序表,值相同的元素一定在连续的位置上,用类似于直接插入排序 的思想,初始时将第一个元素视为非重复的有序表。之后依次判断后面的元素是否与前面非重复有序表的最后一个元素相同,若相同,则继续向后判断,若不同,则插入前面的非重复有序表的最后,直至判断到表尾为止。

#include<iostream>
using namespace std;
const int maxn=100;
int len;
typedef struct
{
    int data[maxn];
    int length;
}Sqlist;
bool del_same(Sqlist &l)
{
    l.length=len;
    if(l.length==0) return false;
    int i,j;
    for(i=0,j=1;j<len;j++)
    {
        if(l.data[i]!=l.data[j]) l.data[++i]=l.data[j];
    }
    l.length=i+1;
    len=l.length;
    return true;
}
int main()
{
    Sqlist lis;
    cin>>len;//输入顺序表的长度
    for(int i=0;i<len;i++)
    {
        cin>>lis.data[i];
    }
    del_same(lis);
    for(int i=0;i<len;i++)
        cout<<lis.data[i]<<" ";
    return 0;
}

运行结果:

7.将两个有序顺序表合并为一个新的有序顺序表,并由函数返回结果顺序表。

思路:首先,双指针i、j,按顺序不断取下两个顺序表表头较小的结点存入新的顺序表中。然后,看哪个表还有剩余,将剩下的部分加到新的顺序表后面。

#include<iostream>
using namespace std;
const int maxn=100;
typedef struct
{
    int data[maxn];
    int length;
}Sqlist;
bool mergeab(Sqlist &lisa,Sqlist &lisb,Sqlist &lis)
{
    int i=0,j=0,k=0;
    if(lisa.length+lisb.length>lis.length) return false;
    while(i<lisa.length&&j<lisb.length)
    {
        if(lisa.data[i]<=lisb.data[j]) lis.data[k++]=lisa.data[i++];
        else lis.data[k++]=lisb.data[j++];
    }
    while(i<lisa.length) lis.data[k++]=lisa.data[i++];
    while(j<lisb.length) lis.data[k++]=lisb.data[j++];
    lis.length=k;
    return true;

}
int main()
{
    Sqlist lis,lisa,lisb;
    cin>>lisa.length>>lisb.length>>lis.length;//输入顺序表a,b的长度,顺序表lisb的元素
    for(int i=0;i<lisa.length;i++)//输入顺序表lisa的元素
    {
        cin>>lisa.data[i];
    }
    for(int i=0;i<lisb.length;i++)//输入顺序表lisb的元素
    {
        cin>>lisb.data[i];
    }
    mergeab(lisa,lisb,lis);
    for(int i=0;i<lis.length;i++)
        cout<<lis.data[i]<<" ";
    return 0;
}

运行结果:

 

8.已知在一维数组A[m+n]中依次存放两个线性表(a1,a2,...,a_{m})和(b1, b2, ...,b_{n})。编写一个函数,将数组中两个顺序表的位置互换,即将(b1, b2, ...,b_{n})放在(a1,a2,...,a_{m})的前面。

思路:先将数组中的全部元素原地逆置,再对前n个元素和后m个元素分别使用逆置算法。

#include<iostream>
using namespace std;
const int maxn=100;
typedef struct
{
    int data[maxn];
    int length;
}Sqlist;
void rev(Sqlist &l,int st,int en)
{
    int tem;
    for(int i=st,j=en;j-i>=1;i++,j--)
    {
        tem=l.data[i];
        l.data[i]=l.data[j];
        l.data[j]=tem;
    }
}
int main()
{
    Sqlist lis;
    int m,n;
    cin>>m>>n;
    lis.length=m+n;
    for(int i=0;i<m;i++)//输入顺序表前m个元素
    {
        cin>>lis.data[i];
    }
    for(int i=m;i<m+n;i++)//输入顺序表前n个元素
    {
        cin>>lis.data[i];
    }
    cout<<"原始顺序表:"<<endl;
    for(int i=0;i<lis.length;i++)
        cout<<lis.data[i]<<" ";
    cout<<endl;
    rev(lis,0,m+n-1);
    rev(lis,0,n-1);
    rev(lis,n,m+n-1);
    cout<<"置换后的顺序表:"<<endl;
    for(int i=0;i<lis.length;i++)
        cout<<lis.data[i]<<" ";
    cout<<endl;
    return 0;
}

运行结果: 

 

9.线性表 (a1,a2,...,a_{n})中的元素递增有序且按顺序存储于计算机内。要求设计一个算法, 完成用最少时间在表中查找数值为x的元素,若找到,则将其与后继元素位置相交换, 若找不到,则将其插入表中并使表中元素仍递增有序

思路:顺序存储的线性表递增有序,可以顺序查找,也可以折半查找。题目要求“用最少的时间在表中查找数值为x的元素”,这里应使用折半查找法。

#include<iostream>
using namespace std;
const int maxn=100;
typedef struct
{
    int data[maxn];
    int length;
}Sqlist;
//二分查找元素x
void findx(Sqlist &l,int x)
{
    int left=0,right=l.length-1,mid;
    while(left<=right)
    {
        mid=left+right>>1;
        if(x==l.data[mid]) break;
        else if(x>l.data[mid]) left=mid+1;//在右侧
        else right=mid-1;//在左侧
    }
    if(l.data[mid]==x&&left!=l.length-1)//找到啦x,且不在最后一个位置,则可以与后继节点交换
    {
        int tem=l.data[mid];
        l.data[mid]=l.data[mid+1];
        l.data[mid+1]=tem;
    }
    //没有找到
    //由于经过二分查找之后,能确定x在right在右边,即在right的后插入x
    if(left>right)
    {
        int i;
        for(i=l.length-1;i>right;i--) l.data[i+1]=l.data[i];//元素后移
        l.data[i+1]=x;//插入x
        l.length+=1;//更新一下顺序表的长度
    }
}
int main()
{
    Sqlist lis;
    cin>>lis.length;
    for(int i=0;i<lis.length;i++)//输入顺序表前m个元素
    {
        cin>>lis.data[i];
    }
    int x;
    cout<<"输入要查找的元素值x:"<<endl;
    cin>>x;
    findx(lis,x);
    for(int i=0;i<lis.length;i++)
        cout<<lis.data[i]<<" ";
    cout<<endl;
    return 0;
}

运行结果: 

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

XCTF:NewsCenter

一道简单的常规注入题&#xff0c;就当练练手了 尝试’ 直接网页异常&#xff0c;尝试进行闭合# 网页恢复正常&#xff0c;证明SQL语句通过单引号进行闭合&#xff0c;则为字符型注入 直接判断字段数&#xff0c;order by n order by 3#回显正常&#xff0c;order by 4#网页异…

kaggle平台学习复习笔记 | 数据划分与模型集成

目录数据集划分与交叉验证模型集成方法Titanic为例的简单应用kaggle比赛相关tips数据集划分与交叉验证 数据集划分 通常有两种方法&#xff1a; 留出法(Hold-out) 适用于数据量大的情况K折交叉验证(K-fold CV) 适用于数据量一般情况 时间比较长自助采样(Bootstrap) 较少使用 …

Lua C接口编程(二)

引言 上篇文章我们学习了C如何调用Lua&#xff0c;今天我们就来聊聊Lua 如何调用C。 Lua版本&#xff1a;Lua 5.3.5 对于Lua提供的接口有不清楚的&#xff0c;可以参考Lua接口官方文档 一、Lua调用C步骤 需要将C文件编译成动态库在Lua文件中使用package.cpath配置C动态库路…

Linux学习笔记——分布式内存计算Spark安装部署

5.12、分布式内存计算Spark环境部署 5.12.1、简介 Spark是一款分布式内存计算引擎&#xff0c;可以支撑海量数据的分布式计算。 Spark在大数据体系是明星产品&#xff0c;作为最新一代的总和计算引擎&#xff0c;支持离线计算和实时计算。 在大数据领域广泛应用&#xff0c…

虚拟化技术考试重点总结

虚拟化技术考试重点总结 什么是虚拟化&#xff1f;其作用是什么 ​ 虚拟化&#xff0c;是指通过虚拟化技术将一台计算机虚拟为多台逻辑计算机。可以在一台计算机上同时运行多个逻辑计算机&#xff0c;每个逻辑计算机可运行不同的操作系统&#xff0c;并且应用程序都可以在相互…

Golang中http编程

http介绍 编写web语言&#xff1a; 1.java 2.php&#xff0c;现在都在尝试用go语言编写 3.python&#xff0c;豆瓣 4.go语言 》 beego&#xff0c;gin两个主流的web框架 https协议&#xff1a;我们使用浏览器访问的时候发送的就是http请求 http是应用层的协议&#xff0c;底…

论文投稿指南——中文核心期刊推荐(地质学)

【前言】 &#x1f680; 想发论文怎么办&#xff1f;手把手教你论文如何投稿&#xff01;那么&#xff0c;首先要搞懂投稿目标——论文期刊 &#x1f384; 在期刊论文的分布中&#xff0c;存在一种普遍现象&#xff1a;即对于某一特定的学科或专业来说&#xff0c;少数期刊所含…

广告业务系统 之 辅助决策 —— “ AB 实验平台”

文章目录广告业务系统 之 辅助决策 —— “ AB 实验平台”AB 实验平台流量侧 & 渲染侧AB 实验模块架构设计智能流控广告业务系统 之 辅助决策 —— “ AB 实验平台” AB 实验平台 在广告业务中&#xff0c;数据通常作为业务前进的内在驱动力之一。 AB 实验平台就是以实验…

java获取时间并进行计算

前言 SimpleDateFormat使用介绍 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、SimpleDateFormat是什么&#xff1f; 如果你对java源码比较了解。你会发现java对文字&#xff0c;数字的格式化&#xff0c;是有一个公共的父类的Format。 NumberFo…

.Net Core6.0程序发布到IIS支持apk文件下载

ASP.Net Core6.0 WebApi程序发布到IIS支持apk/wgt文件下载 IIS中配置MIME 添加.apk/.wgtapplication/vnd.android.package-archive或application/octet-stream.Net Core6.0 WebApi 程序要在startup.cs中设置 //使用默认文件 app.UseDefaultFiles(); //开启静态文件 app.UseS…

金山区企业工程技术研究中心给予15万元资金奖励

金山区企业工程技术研究中心一、主管部门金山区科学技术委员会二、政策依据《金山区关于进一步鼓励科技创新加快上海科技创新中心重要承载区建设的若干配套政策》&#xff08;金府发〔2020〕3号&#xff09;《金山区关于进一步鼓励科技创新加快上海科技创新中心重要承载区建设的…

赛题发布|“星河杯”隐私计算大赛-赛题发布沙龙成功举办

2023年1月10日下午&#xff0c;由中国信通院与隐私计算联盟主办&#xff0c;中移动信息技术有限公司、联通数字科技有限公司、天翼电子商务有限公司共同协办&#xff0c;FATE开源社区提供技术支持&#xff0c;DataFountain作为官方竞赛平台的“星河杯”隐私计算大赛顺利举办赛题…

Acwing---1212.地宫取宝

地宫取宝1.题目2.基本思想3.代码实现1.题目 X 国王有一个地宫宝库&#xff0c;是 nm 个格子的矩阵&#xff0c;每个格子放一件宝贝&#xff0c;每个宝贝贴着价值标签。 地宫的入口在左上角&#xff0c;出口在右下角。 小明被带到地宫的入口&#xff0c;国王要求他只能向右或…

SAP入门技术分享三:模块化程序

模块化程序1.子程序概要2.子程序定义3.子程序参数&#xff08;1&#xff09;传递参数的方法&#xff08;2&#xff09;定义参数类型&#xff08;3&#xff09;参数与结构体&#xff08;4&#xff09;参数与内表4.调用子程序&#xff08;1&#xff09;调用程序内部子程序&#x…

Android APP 缓存路径

Context.getCacheDir():这个缓存路径打印出来的是&#xff1a;data / data / (APPID ) / cacheAndroid系统中的清除APP缓存清除的就是这个路径: 随着用户手动清空缓存或者APP的卸载&#xff0c;这个路径的缓存也会被删除。请注意&#xff1a;在这个缓存路径上读写是不需要请求文…

Qt扫盲-信号槽理论总结

信号槽理论总结一、概述二、信号槽三、信号四、槽函数五、小例子六、 信号槽的默认参数七、高级使用八、 在Qt 里使用第三方的信号槽一、概述 信号和槽用于对象之间的通信。信号和槽机制是Qt的一个核心特性&#xff0c;也是与其他框架所提供的特性最大不同的部分。Qt的元对象系…

win10跨网段文件共享

win10跨网段文件共享问题描述问题分析网络可达性防火墙权限问题操作网络拓扑示意图操作步骤问题描述 平常&#xff0c;我们经常用的是同一局域网下的网络共享&#xff0c;这在windows上很容易操作。现在&#xff0c;两台PC主机不在同一子网&#xff0c;该如何共享&#xff1f;…

【C/C++】静态顺序表详解(附完整源码)

本章内容 1.什么是线性表 2.什么是顺序表 3.静态顺序表结构的定义 4.静态顺序表的函数接口实现 5.静态顺序表的问题及思考 1.什么是线性表 线性表&#xff08;linear list&#xff09;是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构&…

开源飞控初探(四)ArduPilot::Copter固件源码分析

2022.5.7&#xff0c;基于v4.0.5的分析。官网文档没及时更新&#xff0c;本文对当前版本源码的描述可能和官网不一样。1、无人机全栈分层结构图2、Flight Code固件部分上图中的Flight Code层&#xff0c;分为5个部分&#xff1a;车机层。一份代码通过编译配置&#xff0c;可以支…

行转列,动态列枚举分组

【问题】Hi All,Thanks for the wonderful support the community gets from this forum.I am trying to accomplish this in MongoDB. Didn’t think it could get this complicated. thought the problem was interesting to solve.I am trying to get a count of students b…