c++ 函数模板案例-排序

函数模板案例

功能实现:

  • 利用函数模板封装一个排序的函数,可以对不同数据类型数组进行排序
  • 排序规则从大到小,排序算法为选择排序
  • 分别利用char数组int数组进行测试

示例:

//交换的函数模板
template<typename T>
void mySwap(T &a, T&b){
    
    
	T temp = a;
	a = b;
	b = temp;
}


template<class T> // 也可以替换成typename
//利用选择排序,进行对数组从大到小的排序
void mySort(T arr[], int len){
    
    
	for (int i = 0; i < len; i++){
    
    
		int max = i; //最大数的下标
		for (int j = i + 1; j < len; j++){
    
    
			if (arr[max] < arr[j]){
    
    
				max = j;
			}
		}
		if (max != i){
    
     //如果最大数的下标不是i,交换两者
			mySwap(arr[max], arr[i]);
		}
	}
}

template<typename T>
void printArray(T arr[], int len) {
    
    
	for (int i = 0; i < len; i++) {
    
    
		cout << arr[i] << " ";
	}
	cout << endl;
}

void test01(){
    
    
	//测试char数组
	char charArr[] = "bdcfeagh";
	int num = sizeof(charArr) / sizeof(char);
	mySort(charArr, num);
	printArray(charArr, num);
}

void test02(){
    
    
	//测试int数组
	int intArr[] = {
    
     7, 5, 8, 1, 3, 9, 2, 4, 6 };
	int num = sizeof(intArr) / sizeof(int);
	mySort(intArr, num);
	printArray(intArr, num);
}

int main() {
    
    

	test01();
	test02();

	system("pause");
	return 0;
}

总结:模板可以提高代码复用,需要熟练掌握

猜你喜欢

转载自blog.csdn.net/weixin_48245161/article/details/113616363
今日推荐