• <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 閱讀(748) 評論(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久久精品免费看国产| 亚洲综合久久夜AV | 老男人久久青草av高清| 国产无套内射久久久国产| 色99久久久久高潮综合影院| 精品国产日韩久久亚洲| 国产aⅴ激情无码久久| 久久国产乱子伦精品免费强| 亚洲欧美日韩久久精品| 99精品久久精品一区二区| 久久96国产精品久久久| 伊人精品久久久久7777| 久久97精品久久久久久久不卡| 久久久久久久久久久免费精品| 国产成人久久精品区一区二区| 久久久久久国产a免费观看黄色大片 | 亚洲中文字幕无码久久综合网| 国产高潮国产高潮久久久| 伊人色综合九久久天天蜜桃| 国产V综合V亚洲欧美久久 | 亚洲中文字幕无码久久2020| 久久国产精品国产自线拍免费| 久久久久久精品免费免费自慰| 久久精品国产亚洲AV不卡| 乱亲女H秽乱长久久久| 精品国产乱码久久久久软件| 久久高清一级毛片| 久久久中文字幕日本| 国产免费久久精品99久久| 久久人妻少妇嫩草AV无码专区| 亚洲va中文字幕无码久久| 亚洲αv久久久噜噜噜噜噜| 模特私拍国产精品久久| 久久影视综合亚洲| 久久久久香蕉视频| 久久久久久久亚洲精品| 久久久久久久综合综合狠狠| 国产精品熟女福利久久AV| 国产激情久久久久影院小草| 国产成人精品综合久久久| 久久99精品久久久久久秒播|