<del id="d4fwx"><form id="d4fwx"></form></del>
      <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

            <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
          • STL函數(shù)對(duì)象的定義及其在STL中的應(yīng)用是怎樣的-創(chuàng)新互聯(lián)

            STL函數(shù)對(duì)象的定義及其在STL中的應(yīng)用是怎樣的,針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。

            創(chuàng)新互聯(lián)建站是專業(yè)的商丘網(wǎng)站建設(shè)公司,商丘接單;提供成都做網(wǎng)站、成都網(wǎng)站建設(shè)、成都外貿(mào)網(wǎng)站建設(shè),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行商丘網(wǎng)站開發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!

            一、函數(shù)對(duì)象定義與實(shí)例

            1.1 定義

                函數(shù)對(duì)象:一個(gè)重載了運(yùn)算符()的個(gè)對(duì)象,可以像一個(gè)函數(shù)一樣使用。

            1.2 實(shí)例

            #include <iostream>
            using namespace std;
            
            class Add
            {
            public:
            	int operator() (int val1, int val2)
            	{
            		return val1 + val2;
            	}
            };
            
            int main(int argc, char *argv[])
            {
            	Add add;cout<<add(3, 5)<<endl;
            	return 1;
            };

            二、函數(shù)對(duì)象在STL中的應(yīng)用

            2.1 統(tǒng)計(jì)vector中大于0的元素的個(gè)數(shù)

                  一個(gè)自定義函數(shù)pred。

                  count_if可以統(tǒng)計(jì)容器中滿足特定條件的元素的個(gè)數(shù)。

            #include <iostream>
            #include <vector>
            #include <algorithm>
            using namespace std;
            
            bool pred(int val)
            {
            	return val > 0;
            }
            
            int main(int argc, char *argv[])
            {
            	vector<int> vec;
            	vec.push_back(-2);
            	vec.push_back(0);
            	vec.push_back(8);
            	vec.push_back(12);
            	vec.push_back(-4);
            
            	cout<<count_if(vec.begin(), vec.end(), pred)<<endl;
            
            
            	return 1;
            };

                  如果想統(tǒng)計(jì)vector中大于10、大于20的元素的個(gè)數(shù),需要重新寫函數(shù)pred。

                  如果有一種辦法,可以使用count_if(vec.begin(), vec.end(), pred(n))直接統(tǒng)計(jì)出vector中元素大于n的元素個(gè)個(gè)數(shù),多好啊。

            2.2 統(tǒng)計(jì)vector中大于n的元素的個(gè)數(shù)

                  一個(gè)自定義函數(shù)對(duì)象。

                  count_if。

            #include <iostream>
            #include <vector>
            #include <algorithm>
            using namespace std;
            
            class pred
            {
            public:
            	pred(int val) : m_val(val) { }
            
            public:
            	bool operator() (int val)
            	{
            		return val > m_val;
            	}
            
            private: 
            	int m_val;
            };
            
            int main(int argc, char *argv[])
            {
            	vector<int> vec;
            	vec.push_back(-2);
            	vec.push_back(0);
            	vec.push_back(8);
            	vec.push_back(12);
            	vec.push_back(-4);
            
            	cout<<count_if(vec.begin(), vec.end(), pred(0))<<endl;
            
            
            	return 1;
            };

            2.3 利用模板技術(shù),可以應(yīng)用到各種類型的容器上

                  函數(shù)對(duì)象

                  模板

                  count_if

            #include <iostream>
            #include <vector>
            #include <algorithm>
            using namespace std;
            
            template<typename T>
            class pred
            {
            public:
            	pred(T val) : m_val(val) { }
            
            public:
            	bool operator() (T val)
            	{
            		return val > m_val;
            	}
            
            private: 
            	T m_val;
            };
            
            int main(int argc, char *argv[])
            {
            	//
            	vector<int> vec;
            	vec.push_back(-2);
            	vec.push_back(0);
            	vec.push_back(8);
            	vec.push_back(12);
            	vec.push_back(-4);
            
            	cout<<count_if(vec.begin(), vec.end(), pred<int>(0))<<endl;
            
            	//
            	vector<char> vChar;
            	vChar.push_back('a');
            	vChar.push_back('c');
            	vChar.push_back('e');
            
            	cout<<count_if(vChar.begin(), vChar.end(), pred<char>('c'))<<endl;
            
            
            	return 1;
            };

            關(guān)于STL函數(shù)對(duì)象的定義及其在STL中的應(yīng)用是怎樣的問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

            當(dāng)前文章:STL函數(shù)對(duì)象的定義及其在STL中的應(yīng)用是怎樣的-創(chuàng)新互聯(lián)
            網(wǎng)站鏈接:http://www.jbt999.com/article30/dooppo.html

            成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)App開發(fā)、品牌網(wǎng)站設(shè)計(jì)、搜索引擎優(yōu)化、云服務(wù)器、網(wǎng)站內(nèi)鏈

            廣告

            聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

            網(wǎng)站托管運(yùn)營(yíng)

              <del id="d4fwx"><form id="d4fwx"></form></del>
              <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

                    <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
                  • 青娱乐国产AV | 日韩在线综合 | 三级三级久久三级久久18 | 啪啪啪网站在线 | 免费大香蕉毛片 |