• <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>

            C++研究

            C++細節深度探索及軟件工程

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              37 隨筆 :: 0 文章 :: 74 評論 :: 0 Trackbacks
            #include "stdafx.h"
            #include 
            <iostream>
            #include 
            <map>
            #include 
            <sstream>
            using namespace std;

            #pragma warning (disable:
            4305)

            typedef map
            <intfloat> FloatMap;
            typedef FloatMap::iterator FloatMapIter;
            typedef FloatMap::const_iterator FloatMapCIter;
            int main()
            {
                FloatMap _map1, _map2;
                _map1[
            1= 0.01;
                _map1[
            3= 0.03;
                _map1[
            4= 0.04;
                _map1[
            5= 0.05;
                _map1[
            7= 0.07;
                _map1[
            101= 0.101;
                _map1[
            109= 0.109;

                _map2[
            1= 0.01;
                _map2[
            4= 0.04;
                _map2[
            5= 0.05;
                _map2[
            7= 0.07;
                _map2[
            101= 0.101;
                _map2[
            103= 0.103;
                _map2[
            108= 0.108;

                FloatMapCIter it1 
            = _map1.begin();
                FloatMapCIter it2 
            = _map2.begin();

                FloatMapCIter it22 
            = _map2.begin();
                FloatMapCIter it11 
            = _map1.begin();
                ostringstream os1; 
            //fenzi
                ostringstream os11; //fenmu1
                ostringstream os22; //fenmu2

                
            //是否有公共部分
                int flag = 0;

                
            while(it1 != _map1.end())
                
            {
                    
            int id = (*it1).first;
                    
            float v1 = (*it1).second;

                    
            while( it22 != _map2.end() && (*it22).first < id) ++it22;

                    
            if( it22 == _map2.end())
                    
            {
                        
            break;
                    }


                    
            if( (*it22).first == id )
                    
            {
                        
            //有公共部分
                        flag = 1;
                        os1 
            << (*it22).first <<  "  "//fenzi
                        cout << (*it22).second << "*" << v1 << endl;
                        it22
            ++;
                    }

                    
            //it2 -- it22
                    FloatMapCIter itemp = it2;
                    
            while( itemp != it22)
                    
            {
                        os22 
            << (*itemp).first << "  " ; //fenmu
                        ++itemp;
                    }

                    it2 
            = it22;
                    
                    
            int id2 = (*it2).first;
                    
            float v2 = (*it2).second;
                    
            while( it11 != _map1.end() && (*it11).first < id2)
                    
            {
                        
            ++it11;
                    }


                    
            if ( it11 == _map1.end())
                    
            {
                        
            break;
                    }


                    
            if( (*it11).first == id2 )
                    
            {
                        
            //有公共部分
                        flag = 1;
                        os1 
            << (*it11).first << "  "//fenzi
                        cout << (*it11).second << "*" <<  v2 << "  ";
                        it11
            ++;
                    }

                    itemp 
            = it1;
                    
            while( itemp != it11)
                    
            {
                        os11 
            << (*itemp).first << "  " ; //fenmu
                        ++itemp;
                    }
                
                    it1 
            = it11;    

                }
            //while

                
            //是否有公共部分
                if (flag == 1)
                
            {
                    
            while( it2 != _map2.end() )
                    
            {
                        os22 
            << (*it2).first << "  " ; //fenmu
                        ++it2;
                    }


                    
            while( it1 != _map1.end() )
                    
            {
                        os11 
            << (*it1).first << "  " ; //fenmu
                        ++it1;
                    }

                }

                
            else
                
            {
                    
            return 0;
                }

                
                    
                


                cout 
            << "Common:" << os1.str() << endl;
                cout 
            << "fenmu:" << os11.str() << endl;
                cout 
            << "fenmu:" << os22.str() << endl;

                system(
            "pause");

                
            return 0;
            }
            posted on 2008-01-15 21:12 常興龍 閱讀(2170) 評論(1)  編輯 收藏 引用 所屬分類: STLAlgorithmACM

            評論

            # re: 求有序序列公共部分(集合交集的O(n)復雜度求法) 2014-04-10 15:34 黃智
            取交集可不是這么取的吧?一趟循環即可!  回復  更多評論
              

            > hi的博客
            99久久99久久精品免费看蜜桃| 久久亚洲国产成人影院| 久久久久夜夜夜精品国产| 51久久夜色精品国产| 欧美久久久久久午夜精品| 久久久久亚洲AV成人网人人网站| 久久99精品国产麻豆宅宅| 99麻豆久久久国产精品免费| 国产精品免费久久久久久久久| 一级a性色生活片久久无少妇一级婬片免费放 | 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 久久婷婷国产麻豆91天堂| 国产成人综合久久精品尤物| 精品久久久久久久国产潘金莲 | 国产精品久久婷婷六月丁香| 久久国产乱子伦免费精品| 精品熟女少妇aⅴ免费久久| 7777精品久久久大香线蕉| 香蕉久久一区二区不卡无毒影院| 国产精品美女久久福利网站| 久久er热视频在这里精品| 国内精品久久国产| 99久久成人18免费网站| 亚洲αv久久久噜噜噜噜噜| 久久国产精品偷99| 精品国产一区二区三区久久久狼| 日韩亚洲国产综合久久久| 久久国产精品-国产精品| 亚洲а∨天堂久久精品9966| 九九久久99综合一区二区| 亚洲va久久久噜噜噜久久天堂| 久久精品国产国产精品四凭 | 四虎久久影院| 久久国产乱子精品免费女| 亚洲色婷婷综合久久| 武侠古典久久婷婷狼人伊人| Xx性欧美肥妇精品久久久久久| 婷婷久久香蕉五月综合加勒比| 亚洲AV伊人久久青青草原| 久久99精品久久久久久9蜜桃| 国产精品天天影视久久综合网|