日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

STL1-函数模板

發布時間:2025/3/15 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 STL1-函数模板 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?1、函數模板和普通函數區別

//普通函數可以進行自動類型轉換, //函數模板必須精確類型匹配; //函數模板可以被重載;c++優先考慮普通函數;#include<iostream> using namespace std; //函數模板-->產生模板函數-->調用函數 template<class T> T MyAdd(T a, T b) {cout << "調用函數模板" << endl;return a + b; } void MyAdd(int a, int b) {cout << "調用函數" << endl; } int main() {int a = 10, b = 20;MyAdd(a, b); double da = 1.12, db = 1.14;MyAdd(da, db); MyAdd(2, 'A');return 0; }

運行結果:?

2、函數模板機制

?

#include<iostream> using namespace std; //函數模板-->產生模板函數-->調用函數 template<class T> T MyAdd(T a, T b) {return a + b; } int main() {int a = 10, b = 20;MyAdd(a, b); //產生MyAdd(int a,int b)函數并調用double da = 1.12, db = 1.14;MyAdd(da,db); //產生MyAdd(double a,double b)函數并調用MyAdd(a, a); //直接調用第一次產生的MyAdd(int a,int b)函數return 0; }

3、函數模板應用-int類型和char類型排序

?

#include<iostream> using namespace std; //對char類型和Int類型數組進行排序 //void PrintArray(int *arr, int len) //{ // for (int i = 0; i < len; i++) // { // cout << arr[i] << " "; // } // cout << endl; //} template<class T> void PrintArray(T *arr, int len) {for (int i = 0; i < len; i++){cout << arr[i] << " ";}cout << endl; } void MySwap(int &a, int &b) {int temp = a;a = b;b = temp; }//冒泡排序 void MySort(int* arr, int len) {for (int i = 0; i < len; i++){for (int j = 0 ;j < len-i-1; j++){if (arr[j] < arr[j+1])MySwap(arr[j], arr[j+1]);}} } //選擇排序 //void MySort1(int* arr, int len) //{ // for (int i = 0; i < len; i++) // { // for (int j = i+1; j < len; j++) // { // if (arr[i] < arr[j]) // { // int temp = arr[i]; // arr[i] = arr[j]; // arr[j] = temp; // } // } // } //} template<class T> void MySort1(T* arr, int len) {for (int i = 0; i < len; i++){for (int j = i + 1; j < len; j++){if (arr[i] < arr[j]){T temp = arr[i];arr[i] = arr[j];arr[j] = temp;}}} } int main(void) {//數組int arr[] = { 2,6,1,8,9,2 };//數組長度int len = sizeof(arr) / sizeof(int);cout << "排序前:";PrintArray(arr, len);MySort1(arr, len);cout << "排序后:";PrintArray(arr, len);char chArr[] = { 'a','c','f','b','e' };int lench = sizeof(chArr) / sizeof(char); cout << "排序前:";PrintArray(chArr, lench); MySort1(chArr, lench);cout << "排序后:";PrintArray(chArr, lench);return 0; }

總結

以上是生活随笔為你收集整理的STL1-函数模板的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。