任务:用选择排序对不同类型的数组进行排序
#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;
}