博客
关于我
第3-4周练习题2020——1-5 线性表元素的区间删除 (20分)
阅读量:443 次
发布时间:2019-03-03

本文共 1183 字,大约阅读时间需要 3 分钟。

以下是重新优化后的内容:


函数接口定义:

List Delete(List L, ElementType minD, ElementType maxD);

其中List结构定义如下:

typedef int Position;typedef struct LNode *List;struct LNode {    ElementType Data[MAXSIZE];    Position Last; /* 保存线性表中最后一个元素的位置 */};

L是用户传入的一个线性表,其中ElementType元素可以通过>、==、<进行比较;minD和maxD分别为待删除元素的值域的下、上界。函数Delete应将Data[]中所有值大于minD而且小于maxD的元素删除,同时保证表中剩余元素保持顺序存储,并且相对位置不变,最后返回删除后的表。


输入样例:

104 -8 2 12 1 5 9 3 3 100 4

输出样例:

4 -8 12 5 9 10

思路

为了实现删除特定范围内的元素功能,我们需要遍历线性表中的每个元素,检查其是否满足删除条件(即大于minD且小于maxD)。满足条件的元素将被存储到一个临时数组中。处理完所有元素后,将临时数组中的元素复制回原线性表中,更新线性表的最后一个位置指针,返回修改后的线性表。

代码实现

List Delete(List L, ElementType minD, ElementType maxD) {    List temp;    int j = 0;    for (int i = 0; i <= L->Last; i++) {        if (L->Data[i] > minD && L->Data[i] < maxD) {            temp.Data[j++] = L->Data[i];        }    }    for (int k = 0; k < j; k++) {        L->Data[k] = temp.Data[k];    }    L->Last = j - 1;    return L;}

解释

  • 初始化临时数组:创建一个临时线性表temp,用于存储需要保留的元素。

  • 遍历线性表:从线性表的第一个元素开始,逐个检查每个元素是否满足删除条件(即大于minD且小于maxD)。

  • 存储满足条件的元素:如果元素满足条件,将其值添加到临时数组temp中。

  • 复制临时数组到原数组:将临时数组中的元素复制回原线性表的相应位置,覆盖那些需要保留的元素。

  • 更新线性表的最后一个位置指针:将线性表的最后一个位置指针更新为临时数组的长度减一。

  • 返回修改后的线性表:返回删除操作后的线性表。

  • 这种方法确保了线性表中剩余元素的顺序不变,同时也保证了相对位置的正确性。

    转载地址:http://sglm.baihongyu.com/

    你可能感兴趣的文章
    NSOperation基本操作
    查看>>
    NSSet集合 无序的 不能重复的
    查看>>
    NT AUTHORITY\NETWORK SERVICE 权限问题
    查看>>
    ntko文件存取错误_苹果推送 macOS 10.15.4:iCloud 云盘文件夹共享终于来了
    查看>>
    nullnullHuge Pages
    查看>>
    numpy 用法
    查看>>
    Numpy如何使用np.umprod重写range函数中i的python
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>
    oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
    查看>>