其他未完成
This commit is contained in:
@@ -0,0 +1,49 @@
|
||||
// 函数模版
|
||||
|
||||
/*
|
||||
template <class T>
|
||||
函数返回值 函数名(T &n1, T &n2)
|
||||
{
|
||||
// 函数体
|
||||
}
|
||||
*/
|
||||
#include <iostream>
|
||||
#include <cstring>
|
||||
#include <cstdlib>
|
||||
|
||||
using namespace std;
|
||||
namespace my
|
||||
{
|
||||
// 推荐使用 typename 而不是 class,因为 typename 更通用
|
||||
template <typename T>
|
||||
void swap(T &a, T &b)
|
||||
{
|
||||
a ^= b;
|
||||
b ^= a;
|
||||
a ^= b;
|
||||
}
|
||||
|
||||
// 函数模版重载: 用于不同类型的参数
|
||||
template <typename T1, typename T2>
|
||||
void swap(T1 &a, T2 &b)
|
||||
{
|
||||
a ^= b;
|
||||
b ^= a;
|
||||
a ^= b;
|
||||
}
|
||||
}
|
||||
|
||||
int main()
|
||||
{
|
||||
int a = 2, b = 6;
|
||||
cout << a << ", " << b << endl;
|
||||
my::swap(a, b); // 自动推演类型: swap<int>(a, b)
|
||||
cout << a << ", " << b << endl;
|
||||
|
||||
char c = 30;
|
||||
cout << a << ", " << (int)c << endl;
|
||||
my::swap(a, c); // 自动推演类型
|
||||
cout << a << ", " << (int)c << endl;
|
||||
|
||||
return 0;
|
||||
}
|
||||
@@ -0,0 +1,55 @@
|
||||
// 使用函数模版实现对 char 和 int 数组的排序和打印
|
||||
#include <iostream>
|
||||
#include <cstring>
|
||||
#include <cstdlib>
|
||||
|
||||
using namespace std;
|
||||
|
||||
template <typename T>
|
||||
void sort(T arr[], int size)
|
||||
{
|
||||
for (int i = 0; i < size - 1; i++)
|
||||
{
|
||||
int min = i;
|
||||
for (int j = i + 1; j < size; j++)
|
||||
{
|
||||
if (arr[min] > arr[j])
|
||||
{
|
||||
min = j;
|
||||
}
|
||||
}
|
||||
if (min != i)
|
||||
{
|
||||
arr[i] ^= arr[min];
|
||||
arr[min] ^= arr[i];
|
||||
arr[i] ^= arr[min];
|
||||
// T temp = arr[i];
|
||||
// arr[i] = arr[min];
|
||||
// arr[min] = temp;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
template <typename T>
|
||||
void printArr(T arr[], int size)
|
||||
{
|
||||
for (int i = 0; i < size; i++)
|
||||
cout << arr[i] << " ";
|
||||
cout << endl;
|
||||
}
|
||||
|
||||
int main()
|
||||
{
|
||||
int arr1[] = {1, 3, 5, 7, 9, 2, 4, 6, 8, 0};
|
||||
char arr2[] = {'a', 'c', 'e', 'G', 'I', 'b', 'd', 'f', 'h', 'j'};
|
||||
int size1 = sizeof(arr1) / sizeof(arr1[0]);
|
||||
int size2 = sizeof(arr2) / sizeof(arr2[0]);
|
||||
|
||||
sort(arr1, size1);
|
||||
sort(arr2, size2);
|
||||
|
||||
printArr(arr1, size1);
|
||||
printArr(arr2, size2);
|
||||
|
||||
return 0;
|
||||
}
|
||||
Reference in New Issue
Block a user