• <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>
            posts - 20,  comments - 6,  trackbacks - 0

                
            //隊列的使用

                    #include
            <queue>

                            
            //在BFS中會使用到隊列

                        
            //優(yōu)先隊列
                            
                    priority_queue
            <元素類型> Q;
                    Q.push();        
            // 壓入元素
                Q.pop;        // 彈出
                Q.front();     // 取頂元素
                Q.empty();     // 判斷是否為空        

                        
                    
            // 優(yōu)先隊列中默認(rèn)的是大的先出
                    
            // 若要使小的先出,則可在元素類型struct中重載 “<”

                    
            struct node{
                        friend 
            bool operator < (node n1, node n2)
                        {
                            
            return n1.Step > n2.Step; 
                            
            // 小的先出
                        }
                        
            int Step;
                    };

                    
            // 優(yōu)先隊列    取頂時應(yīng)使用  Q.top();




                
            //鏈表的使用

                    #include
            <list>

                    list
            <int> lis;
                    list
            <int>::iterator iter; // 跌代器 (指針)

                    list.push_back(); 
            // 在鏈表尾插入元素

                    
            //操作表中的每個元素時,必須要使用指針
                    
            //    *iter 即為 iter 所指的元素的值

                    
            for(iter = lis.begin(); iter != lis.end(); iter ++)
                    {    
                        iter 
            = lis.erase(iter);
                        
            // 刪除表中一位置的元素
                        
            // 若刪除指定位置,第 i 個,可用 i 記數(shù) 
                    }

                    
            //    lis.insert() 插入在當(dāng)前指針?biāo)傅脑刂?br>

                
            //容器    vector 的使用

                    #include
            <vector>
                    
                    vector
            <int> v;
                    v.push_back();    
            // 在尾部插入元素
                    v.size();        // 返回容器的大小
                    v.clear();        // 清除容器的元素
                    v.resize();        //分配表的大小

                    
            //若使用vector 來表示二維,則可

                    vector
            <vector<int>  > v(n);
                    
            //或者
                    vector<vector<int> > v;
                    v.resize(n);

                    
            // 可以表示有 n 行的二維數(shù)組
                    
            // 對于每一維 , v[i] 的操作與 v 一致
                    

                    
                    
            // 傳 vector 的使用
                    void pp(vector<vector<int> >  &vv)
                    {
                        
            // 傳vector 的函數(shù)使用

                        
            int i ,j;
                        
            for(i = 0 ; i < vv.size(); i ++)
                        {
                            
            for(j = 0 ; j < vv[i].size(); j ++)
                                printf(
            "%d ",vv[i][j]);
                            printf(
            "\n");
                        }
                    }

                    
            void main()
                    {
                        
            int i,j;

                        vector
            <vector<int > > a(10);

                        
            for(i = 0 ; i < 10 ; i++)
                            
            for(j  = 0 ; j < i;j ++)
                                a[i].push_back(j);
                        
                        pp(a);
                        
                        
            // 調(diào)用函數(shù)
                    }






                
            // C++ 自帶的排序 sort

                    #include
            <algorithm>
                        
            //頭文件

                    
            bool cmp(int a, int b){
                        
            return a > b;
                    }    
            // 使得降序排列

                    
            //默認(rèn)為升序    sort(a,a + n);

                    sort(A, A
            +n,cmp);

                    
            //也可對結(jié)構(gòu)體排序,比較函數(shù)自己實現(xiàn)


                
            // 要對容器中的元素排序

                    
            // 可使用跌代器
                    
            // 把容器中起始與結(jié)束的指針傳給 sort

                
            // example

                    vector
            <int> v;
                    vector
            <int> ::iterator it1;
                    vector
            <int> ::iterator it2;

                    it1 
            = v.begin();
                    it2 
            = v.end();

                    sort(it1, it2 ,cmp);



                
            // string

                    
            // 使用起來相對比較多 , 主要在處理字符串的時候
                    
                    #include
            <string>
                    
                     
            string  s1 , s2 , s3;
                    
                    
            // string 類的賦值
                    
            // 即可以 相互之間,也可以把字符串直接賦給 string 類
                
            // example
                    
                     
            char ss[] = “abcd”;
                    s1 
            = “”;         // string 類初始為空
                s1 = ss ;        //    把字符串直接賦給string
                s2 = s1;        // sgring 之間賦值
                
                
            // string 類可以直接使用 + 來進(jìn)行字符串的拼接
                
                     s1 
            = “ab”;
                     s2 
            = “cd”;
                    s3 
            = s1 + s2;
                    
            //    操作的結(jié)果 s3 == “abcd”;
                
            // 常用的函數(shù)     
                s1.size();     // 字符串的大小,既長度
                
            // 對于已經(jīng)賦值的字符串,可以直接對下表進(jìn)行操作
                
            // 可以使用查找函數(shù)
                s1.find(s2) ;     // 在s1 中查找 s2 ,如果存在,返回起始下表,否則返回 -1
                s1.substr(起始位置,長度); //取子串
                

            posted on 2009-02-10 18:42 混沌的云 閱讀(549) 評論(2)  編輯 收藏 引用

            FeedBack:
            # re: STL簡單講解
            2009-02-18 21:49 | shǎ崽
            zero  回復(fù)  更多評論
              
            # re: STL簡單講解
            2009-02-18 21:54 | 混沌的云
            @shǎ崽
            囧。。。  回復(fù)  更多評論
              

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(1)

            隨筆檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久夜色精品国产亚洲| 国产精品一久久香蕉国产线看观看 | 亚洲国产高清精品线久久| 久久天天躁狠狠躁夜夜躁2014| 久久成人国产精品免费软件| 99国产精品久久久久久久成人热| 99精品久久久久久久婷婷| 久久精品国产免费观看| 亚洲国产成人久久精品动漫| 热久久视久久精品18| 777久久精品一区二区三区无码| 伊人久久大香线蕉成人| 国产精品久久成人影院| 色狠狠久久综合网| 久久精品国产亚洲Aⅴ蜜臀色欲| 午夜欧美精品久久久久久久| 国产呻吟久久久久久久92| 午夜精品久久久久久久| 无码人妻少妇久久中文字幕| 99re这里只有精品热久久| 99久久精品免费看国产一区二区三区| 久久精品国产精品国产精品污| A级毛片无码久久精品免费 | 免费精品国产日韩热久久| 情人伊人久久综合亚洲| 久久久久久久97| 中文字幕无码av激情不卡久久| 91精品无码久久久久久五月天| 久久99热只有频精品8| 午夜精品久久久久久久久| 久久无码AV一区二区三区| 久久久国产一区二区三区| 久久婷婷国产麻豆91天堂| 久久99国产精品久久99果冻传媒| 日韩精品久久久久久免费| 丁香色欲久久久久久综合网| 久久强奷乱码老熟女网站| 天天影视色香欲综合久久| 久久久精品久久久久特色影视| 国内精品久久久久久不卡影院| 国产亚州精品女人久久久久久|