程序员社区

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

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

任务:用选择排序对不同类型的数组进行排序

#include<iostream>
using namespace std;
//交换函数
template<class t>
void myswap(t& a, t& b)
{
	t temp = a;
	a = b;
	b = temp;
}
//排序函数
template<class T>
void test(T &array,int len)
{
	for (int i = 0; i < len; i++)
	{
		int max = i;
		for (int j = i + 1; j < len; j++)
		{
			if (array[max] < array[j])
			{
				max = j;
			}
		}
		if (max != i)
		{
			swap(array[max], array[i]);
		}
	}
}
//打印数组模板
template<class a>
void printarr(a &arr,int len)
{
	for (int i = 0; i < len; i++)
	{
		cout << arr[i] << " ";
	}
}
int main()
{
	int arr[] = { 2,4,7,5,8,6,10 };
	int len = sizeof(arr) / sizeof(arr[0]);
	test(arr, len);
	printarr(arr, len);
	system("pause");
	return 0;
}

赞(0) 打赏
未经允许不得转载:IDEA激活码 » c++模板篇02函数模板案例----排序函数

相关推荐

  • 暂无文章

一个分享Java & Python知识的社区