动态数组之五:数组排序和搜索

本文介绍了CArrayX中数组关键字的应用及其派生类TKeyArrayFix、TKeyArrayVar和TKeyArrayPak的特性。此外还对比了RArray和RPointerArray在排序和搜索方面的优势,包括它们如何通过封装在TLinearOrder和TIdentityRelation中来提高效率。

*CArrayX

 - 数组关键字可以用来定义数组元素的属性,用来进行整个数组的排序和搜索

 - 数组关键字的抽象基类是TKey,它的派生类有

        ·TKeyArrayFix: 用于长度固定元素的数组

         ·TKeyArrayVar: 用于长度可变元素的数组

         ·TKeyArrayPak: 用于打包元素(长度可变)的数组

-          按关键字顺序访问元素需要构造适当的TKeyArrayFix, TKeyArrayVarTKeyArrayPak对象,并将其传入数组的成员函数Sort(), InsertIsqL(), Find() FindIsq() 

 

*RArrayRPointerArray

 - 排序和搜索相对于CArrayX效率更高

 - RArray RPointerArray包含的对象可以使用元素类的比较函数进行排序

 - 将排序对象封装在TLinearOrder<class T>包中

 - 搜索操作类似,需要封装在TIdentityRelation<class T>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值