• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            The Fourth Dimension Space

            枯葉北風寒,忽然年以殘,念往昔,語默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢令

            TopCoder競賽:C++, STL 用法快速入門(轉)

            下面總結了一些題目中常用的STL庫的用法。

             

             
            #include <algorithm>
            #include <string>
            #include <vector>
            #include <map>
            #include <iostream>
             
            using namespace std;
             
            //遞歸
            int GetN(int n)
            {
            if (n==1) return 1;
            else return GetN(n-1);
            }
             
            void TestSTL_main( int argc, char* argv[] )
            //void main( int argc, char* argv[] )
            {
            /******** STL **********/
             
            //string的用法
            {
            string s = "mmmmm";
            string s2("ss22");
            s2.insert(2,"kkkkk"); //把"kkkkk"插到s2的第2個位置之前(位置從0開始)
            s2+=s+"44444"+'c';
            const char *pc = s.c_str();//把string轉成C-style的string,以\0終了
            const char *ptr1 = s.data();;//把string轉成字符串
            if (s2[2] == 'k') s2[2]='C';
            s+="jkl";
            s+='m';
            s.push_back('\n'); //把'\n'(換行符)放在s的最后一個位置
            reverse(s.begin(), s.end()); //反轉
            basic_string <char>::iterator str_Iter; //遍歷
            str_Iter = s.begin();
            }
             
            //vector的用法
            {
            vector<int> v;
            v.push_back(8); //向v中插入元素,元素的值是8
            int iLen = (int)v.size();
            for(int i=0;i<iLen;i++)
            {
            int k = v[0]; //k==8
            }
            }
             
            //map的用法
            {
            map<int, int> mp;
            for(int i=0;i<3;i++)
            {
            mp[i]=i*2; //通過[第一個元素]來訪問第二個元素
            }
             
            int total = 100;
            map<int, int>::iterator it = mp.begin();
            for(;it!=mp.end();it++) //遍歷mp
            {
            total+=it->second; //通過iterator it來訪問第二個元素
            }
            cout<<"total="<<total<<endl;
            }
             
            //算法
            int n = GetN(5); //遞歸n!=n*(n-1)*(n-2)*…*1
            int aa=10,bb=15;
            int maxi = max(aa,bb); //最大值
            int mini = min(aa,bb); //最小值
            int absi = abs(-12); //絕對值
            vector<string> v;
            v.push_back("hello");
            v.push_back("123");
            v.push_back("no");
            sort(v.begin(),v.end()); //按照字母順序,把v里面的元素排序
            int savei;
            sscanf(v[0].c_str(), "%d", &savei); //把字符串“123”轉換成數字123
            cout<<"savei="<<savei<<endl;
            char buf[100];
            sprintf(buf,"v[1]=%d",savei); //把內容打印進字符串
            cout<<"buf="<<buf<<endl;
             
            }

            posted on 2009-10-27 15:35 abilitytao 閱讀(744) 評論(2)  編輯 收藏 引用

            評論

            # re: TopCoder競賽:C++, STL 用法快速入門 2009-10-27 16:33 OwnWaterloo

            代碼很好看。

            GetN(int n)始終返回1? 復制時弄錯了?
              回復  更多評論   

            # re: TopCoder競賽:C++, STL 用法快速入門 2009-10-27 17:00 abilitytao

            @OwnWaterloo
            可能是原作者寫錯了  回復  更多評論   

            三上悠亚久久精品| 伊人色综合久久天天人手人婷| 欧美亚洲国产精品久久| 国产欧美久久久精品| 俺来也俺去啦久久综合网| 99久久精品免费看国产一区二区三区 | 久久精品成人欧美大片| 久久九九有精品国产23百花影院| 亚洲AV无码1区2区久久| 99蜜桃臀久久久欧美精品网站| 亚洲精品美女久久777777| 无遮挡粉嫩小泬久久久久久久| 99精品国产综合久久久久五月天| 久久久久久久女国产乱让韩| 久久成人小视频| 亚洲欧洲日产国码无码久久99| 亚洲国产精品无码久久一线| 久久精品蜜芽亚洲国产AV| 国产精品美女久久久| 久久精品青青草原伊人| 国产成人久久精品一区二区三区 | 2022年国产精品久久久久| 欧美精品久久久久久久自慰| 国产麻豆精品久久一二三| segui久久国产精品| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 亚洲成色WWW久久网站| 亚洲欧美伊人久久综合一区二区| 99久久人妻无码精品系列| 精品无码人妻久久久久久| 久久青青草原精品国产软件| 久久免费看黄a级毛片| 久久久中文字幕| 7777久久久国产精品消防器材| 99久久er这里只有精品18| 国产成人久久精品二区三区| 99蜜桃臀久久久欧美精品网站| 久久精品免费大片国产大片| 亚洲人AV永久一区二区三区久久 | 久久久久久久人妻无码中文字幕爆| 欧美午夜A∨大片久久|