導航:首頁 > 源碼編譯 > std泛型演算法

std泛型演算法

發布時間:2022-12-17 21:21:53

⑴ 泛型演算法unique_的問題

#include<iostream>
#include<algorithm>
#include<vector>
#include<list>
using namespace std;
int main()
{
�0�2int a[]={1,2,3,4,3,5};
�0�2list<int> ilst(a,a+6);
ilst.sort(); �0�2 // 這里需要排序,不排序,unique_不起作用�0�2vector<int> ivec;
�0�2unique_(ilst.begin(),ilst.end(),back_inserter(ivec));
�0�2for(vector<int>::iterator iter=ivec.begin();iter!=ivec.end();++iter)
�0�2 cout<<*iter<<" ";
�0�2cout<<endl;
�0�2return 0;
}

⑵ c++的程序

其實排序,在C++的泛型演算法里有一個 sort() ,直接利用它就不用自己寫代碼,又簡潔,又省力。
我把1 2的代碼入在一個main()里

#include <iostream>
#include <cstdlib> //隨機數產生頭文件
#include <ctime> //包含time()的頭文件
#include <vector>
#include <algorithm> //泛型演算法頭文件

using std::cout;
using std::endl;
using std::cin;
using std::vector;

int main(void)
{

/* 1小題部分 */

int rezult = 1;
int temp = 0;

cout << "please input the number of the end:" << endl;
cin >> temp; //交互部分,輸入階乘上限
while(temp)
{
rezult *= temp--;
}

cout << "rezult:" << rezult << endl << '\n'; // 結果

/* 2小題部分 */

int num = 0;
int rd = 0;
vector<int> TR;
srand(time(0));

cout << "input the number :" << endl;
cin >> num; //輸入需要產生隨機數的個數,10則輸入10

while(num != 0)
{
rd = rand() % 101;
if(rd % 2 != 0 )
TR.push_back(rd);
else
continue;
--num;
}
vector<int>::iterator first = TR.begin();
sort(first, TR.end()); //利用泛型演算法對數排序

while(first != TR.end())
{
cout << *first << " "; // 輸出排序後的數
++first;
}
cout << endl;

return 0;
}

⑶ c++泛型演算法中replace的問題

能學到STL的演算法已經恨牛逼了。
應該改成
replace(sevc.begin(),sevc.end(),string("hello"),string("haha"));
因為演算法中使用模板做形參,所以需要明確類型信息。直接寫"hello"編譯器不知道該處理成什麼類型,所以出錯。

閱讀全文

與std泛型演算法相關的資料

熱點內容
順序表查找演算法 瀏覽:463
整合包解壓後是亂碼 瀏覽:300
xp系統如何查找伺服器名 瀏覽:983
土的壓縮系數的確定方法 瀏覽:647
程序員家裡健身 瀏覽:620
電視看籃球app哪個好 瀏覽:47
高中畢業當程序員 瀏覽:245
php標簽屬性大全 瀏覽:897
遠程訪問伺服器ip地址 瀏覽:312
程序員吃雞蛋炒菜 瀏覽:173
在哪裡看俄羅斯電視劇app 瀏覽:308
怎麼找資料庫伺服器地址 瀏覽:487
伺服器調試怎麼翻譯 瀏覽:921
php如何處理ajax請求 瀏覽:211
php數組下標存在 瀏覽:707
php獲取ip歸屬地 瀏覽:175
撩女程序員怎麼辦 瀏覽:508
百度伺服器做什麼 瀏覽:193
打開軟體加速伺服器有什麼危害 瀏覽:87
php去除數組下標 瀏覽:794