• <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
            可能是原作者寫錯了  回復  更多評論   

            久久天天躁夜夜躁狠狠躁2022| 国产精品一区二区久久精品| 国产成人无码精品久久久免费| 97超级碰碰碰碰久久久久| 久久九九青青国产精品| 久久久久人妻一区精品果冻| 久久婷婷色香五月综合激情| 亚洲AV日韩精品久久久久| 久久久综合九色合综国产| 欧美一级久久久久久久大片| 久久精品国产亚洲AV麻豆网站 | 中文字幕亚洲综合久久菠萝蜜| 午夜精品久久久久久影视riav| 久久精品人人做人人爽97 | 亚洲精品无码久久久久| .精品久久久麻豆国产精品| 久久精品三级视频| 国产精品无码久久久久久| yellow中文字幕久久网| 久久夜色精品国产噜噜亚洲AV| 精品人妻伦九区久久AAA片69| 久久久久青草线蕉综合超碰| 国产AⅤ精品一区二区三区久久| 国色天香久久久久久久小说| 久久精品视屏| 国産精品久久久久久久| 精品久久8x国产免费观看| 亚洲伊人久久精品影院| 亚洲人成网站999久久久综合| 久久免费国产精品一区二区| 国内精品久久久久影院日本| 国产69精品久久久久观看软件| 久久电影网| 久久无码国产| 久久久精品波多野结衣| 久久久久99精品成人片三人毛片| 狠狠狠色丁香婷婷综合久久俺| 精品久久久久久久无码| 久久精品国产亚洲av影院| 久久久久亚洲精品天堂| 国产精品禁18久久久夂久|