一个排序用的C++函数模板

前段时间编写MFC程序时,需要对一个字符串集合CStringArray进行排序。标准模板库STL提供的函数模板sort虽然功能强大,但有两个不便:

1、 sort使用枚举器(iterator)机制处理C++数组(即指针)和诸如vector这样的STL对象,但MFC集合类CArray、CStringArray没有提供枚举器。虽然可以通过集合类的成员函数GetData把集合转换成指针,然后调用sort进行处理,但这样做破坏了对象的封装性。

2、如果使用降序排序,还需要另外编一个比较函数。

为此我自己编写了一个排序用的函数模板,一方面满足自己的需求,另一方面也顺便巩固一下C++基础。该函数模板虽然功能简单一些,但支持C++数组和MFC集合类,支持升序和降序,对于一般应用来说足够了。

函数代码如下:
// 该函数模板使用冒泡法对集合元素进行排序,参数说明:
//   collection    集合对象,集合对象必须提供 [] 操作。
//   element     集合元素,该参数的作用仅仅是确定集合元素类型,
//           参数的值没有用,建议取集合的第一个元素。集合
//           元素必须提供复制、赋值和比较操作。
//   count      集合元素的数目
//   ascend      表明排序时使用升序(true)还是降序(false)
// 该函数模板支持C++数组以及MFC集合CStringArray、CArray。
template <typename COLLECTION_TYPE, typename ELEMENT_TYPE>
void BubbleSort(COLLECTION_TYPE& collection, ELEMENT_TYPE element, int count, bool ascend = true)
{
  for (int i = 0; i < count-1; i++)
    for (int j = 0; j < count-1-i; j++)
      if (ascend)
      {
        // 升序
        if (collection[j] > collection[j+1])
        {
          ELEMENT_TYPE temp = collection[j];
          collection[j] = collection[j+1];
          collection[j+1] = temp;
        }
      }
      else
      {
        // 降序
        if (collection[j] < collection[j+1])
        {
          ELEMENT_TYPE temp = collection[j];
          collection[j] = collection[j+1];
          collection[j+1] = temp;
        }
      }
}
下列代码对整型数组按升序排序:
  int arrayInt[] = {45, 23, 76, 91, 37, 201, 187};
  BubbleSort(arrayInt, arrayInt[0], 7);
下列代码对整数集合按升序排序:
  CArray <int, int> collectionInt;
  collectionInt.Add(45);
  collectionInt.Add(23);
  collectionInt.Add(76);
  collectionInt.Add(91);
  collectionInt.Add(37);
  collectionInt.Add(201);
  collectionInt.Add(187);
  BubbleSort(collectionInt, collectionInt[0], collectionInt.GetSize());
下列代码对一个字符串数组按降序排序:
  CString arrayString[] = {"eagle", "hawk", "falcon"};
  BubbleSort(arrayString, arrayString[0], 3, false);

下列代码对一个字符串集合按降序排序:

CStringArray collectionString;
  collectionString.Add("eagle");
  collectionString.Add("hawk");
  collectionString.Add("falcon");
  BubbleSort(collectionString, collectionString[0], collectionString.GetSize(), false);

时间: 2024-08-01 06:48:14

一个排序用的C++函数模板的相关文章

欧拉函数模板

欧拉函数:表示1-(n-1)中,与n互质的数的个数 本以为学会容斥原理就不必再看欧拉函数,可是偏偏就是有些题用容斥原理解不了,必须参考欧拉,没办法只好回头看欧拉函数 下面贴一个筛法求欧拉函数模板: //初始化eu[1]=0或者eu[1]=1,具体情况根据题目变化! //下面计算2-10000的欧拉函数 const int MAX = 10001; int eu[MAX];//不要忘记初始化eu[1]. void eular(){ for(int i=2;i<MAx;i++){ if(!eu[i]

C++实践参考:排序函数模板

[项目-排序函数模板] 已知 void Sort(int a[],int size); void Sort(double a[],int size); 是一个函数模板的两个实例,其功能是将数组a中的前size个元素按从小到大顺序排列.试设计这个函数模板. 参考解答: #include<iostream> using namespace std; template<class T> void Sort(T set[],int n) { int i,j; T temp; for(i=1

用函数模板,写一个简单高效的 JSON 查询器的方法介绍_javascript技巧

JSON可谓是JavaScript的亮点,它能用优雅简练的代码实现Object和Array的初始化.同样是基于文本的数据定义,它比符号分隔更有语义,比XML更简洁.因此越来越多的JS开发中,使用它作为数据的传输和储存. JS数组内置了不少有用的方法,方便我们对数据的查询和筛选.例如我们有一堆数据: 复制代码 代码如下: var heros = [        // 名============攻=====防=======力量====敏捷=====智力====        {name:'冰室女巫

用函数模板实现和优化抽象操作

摘要:本文介绍函数模板的概念.用途以及如何创建函数模板和函数模板的使用方 法...... 在创建完成抽象操作的函数时,如:拷贝,反转和排序,你必须定义多个版 本以便能处理每一种数据类型.以 max() 函数为例,它返回两个参数中的较大者: double max(double first, double second); complex max(complex first, complex second); date max(date first, date second); //..该函数的 其

C++中函数模板(function template) 详解

C++的模板(template)是泛型编程(generic programming)的基础; 面向对象编程 是 运行(run time)时 知道类型(type); 泛型编程 是编译(compilation) 知道类型; 函数模板(function template)包含模板参数列表(template parameter list); 每个参数类型之前必须包含关键字typename或class, 尽量使用typename, 表达意思更加明确; 非类型模板参数(Nontype Template Pa

C++中函数模板(function template) 的 重载(overload) 详解

函数模板(function template)重载, 即实例化特定的模板, 确定T的类型, 选择匹配度最高的一个; 需要注意传递的具体类型, 如传递的是"&s", 则表示"string* t = &s", 即实际匹配的类型为"string* t"; 当非函数模板和函数模板匹配度相同时, 优先选择非函数模板; 调用模板时, 一定要注意顺序, 或者提前声明, 以保证可以找到函数模板, 进行实例化; 具体参见代码注释, 代码如下: /*

C++:模板类使用成员函数模板处理隐式(implicit)转换

指针支持隐式转换(implicit conversion), 在动态绑定中,派生类指针可以转换为基类指针. 但是模板的实例化(instantiations)之间, 是单独存在的, 派生类的实例化的模板(SmartPtr<Derived>), 不能转换为基类实例化的模板(SmartPtr<Base>); 需要明确的编写, 因为派生类也可以继续做为基类, 产生派生类, 所以无法直接写出构造函数. 使用成员函数模板(member function template), 再声明一个模板参数

HDU 1286 找新朋友(欧拉函数模板)

HDU 1286 找新朋友:http://acm.hdu.edu.cn/showproblem.php?pid=1286 题意:中文题. 思路:欧拉函数的纯模板题,没什么好说的,主要是理解欧拉函数的意义. 在数论,对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目.此函数以其首名研究者欧拉命名,它又称为Euler's totient function.φ函数.欧拉商数等. 例如φ(8)=4,因为1,3,5,7均和8互质.   ----by度娘. 更多精彩内容:http://www.bia

c++重载决议具体化优先于函数模板

问题描述 c++重载决议具体化优先于函数模板 template void f(T a){ cout << "aaaaaaa"; } template <> void f(int & a){ cout << "fffffffffff"; } int b:f(b); 为什么输出aaaaaaa,不是应该输出fffffffffff吗,看书上说具体化优先于模板函数的 求知道的大神指点下啦,万分感谢 解决方案 #include <