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

            cc

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              38 隨筆 :: 14 文章 :: 21 評論 :: 0 Trackbacks
            1,兩個整數集合A,B,求其交集,要求寫出代碼;
            2,求一個論壇的在線人數,假設有一個論壇,其注冊ID有兩憶個,每個ID從登陸到退出會向一個日志文件中記下登陸時間和退出時間,要求寫一個算法統計一天中論壇的用戶在線分布,取樣粒度為秒.
            posted on 2006-12-17 15:31 醒目西西 閱讀(4866) 評論(7)  編輯 收藏 引用 所屬分類: 編程相關

            評論

            # re: 騰訊最新面試題,算法高手請進 2006-12-17 15:32 醒目西西
            對于第二個題目寫了個awk程序
            ~>cat luntan
            #!/usr/bin/awk
            {
            a[$1]++;
            a[$2 +1]--;
            }
            END{
            s=0;
            for(;i<=24*3600;i++)
            {
            s += a[i];
            print "at second "i " total ID = " s;
            }
            }
            測試的話可以手動或用腳本生成日志文件
            ~>awk -f luntan logfile
            or
            ~>echo 2 20 |awk -f luntan   回復  更多評論
              

            # re: 騰訊最新面試題,算法高手請進 2006-12-17 15:32 醒目西西
            我表達的不太清晰,一天有24*3600秒
            每個ID在日志中的數據格式如下:12 200 即該用戶在今天的第12秒到200秒在線
            日志文件中大概有2億個這種記錄,問題是求在一天中的第N 秒的在先人數   回復  更多評論
              

            # re: 騰訊最新面試題,算法高手請進 2006-12-17 15:32 醒目西西
            對于求交集的問題,我的算法是:
            假設
            A 元素個數為 NA
            B 元素個數為 NB
            NA > NB
            對集合B快速排序,然后遍歷集合A的元素在集合B中用2分查找
            復雜度:NB*log(NB) + NA*log(NB)
            如果兩個都排序,光排序的時間就大于這個了   回復  更多評論
              

            # re: 騰訊最新面試題,算法高手請進 2006-12-17 15:32 醒目西西
            第二題的方法
            int delta[86400]; //定義每秒鐘人數的變化數
            memset(delta, 0, sizeof(delta)); //初始化
            //打開文件
            while(!feof(....)){
            int online_tm, int offline_tm; //
            //讀入上線時間和下限時間
            delta[online_tm]++;
            delta[offline_tm]--;
            }
            int result[86400];
            int begin_total; //0:00的在線數,需要初始化
            int totla = begin_total;
            for(int i = 0; i < 86400; i++){
            result[i] = total;
            total += delta[i];
            }

            //到這兒result 就是你要的  回復  更多評論
              

            # re: 騰訊最新面試題,算法高手請進 2006-12-17 15:32 醒目西西
            第一題的方法,這不是一個好辦法,無非是一個解決辦法而已
            std::list<int> unite(const std::list<int>& A, const std::list<int>& B)
            {
            std::map<int, bool> temp;
            for(std::list<int>::const_iterator iter = A.begin(); iter != A.end(); iter ++){
            if(temp.find(*iter) == temp.end()) temp[*iter] = true;
            }
            for(std::list<int>::const_iterator iter = B.begin(); iter != B.end(); iter ++){
            if(temp.find(*iter) == temp.end()) temp[*iter] = true;
            }
            std::list<int> ret;
            for(std::map<int, bool>::const_iterator iter = temp.begin(); iter != temp.end(); iter++){
            ret.push_back(iter->first);
            }
            return ret;
            }   回復  更多評論
              

            # re: 騰訊最新面試題,算法高手請進 2006-12-18 17:43 ZiDing
            A+B快排,然后遍歷  回復  更多評論
              

            # re: 騰訊最新面試題,算法高手請進 2010-01-11 11:36 LiWang1112358
            1.hash不行嗎  回復  更多評論
              

            久久久久国产精品熟女影院| 久久99精品国产麻豆婷婷| 国产激情久久久久久熟女老人| 99精品久久久久久久婷婷| 国产精品久久成人影院| 欧美日韩成人精品久久久免费看| 国产成人久久精品一区二区三区 | 欧美伊香蕉久久综合类网站| 久久99精品久久久久久9蜜桃| 亚洲第一永久AV网站久久精品男人的天堂AV | 久久免费精品一区二区| 亚洲精品乱码久久久久久蜜桃| 久久ZYZ资源站无码中文动漫| 久久久久久毛片免费看| 久久九九有精品国产23百花影院| 亚洲国产精品无码久久九九| 91精品国产91久久久久久青草| 亚洲愉拍99热成人精品热久久| 久久夜色撩人精品国产小说| 夜夜亚洲天天久久| 国产精品久久久久天天影视| 久久精品水蜜桃av综合天堂| 免费无码国产欧美久久18| 久久久久亚洲AV无码专区桃色 | 一本久久久久久久| 久久综合久久综合九色| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 久久成人18免费网站| 久久国产精品成人免费| 久久精品无码一区二区无码 | 一本综合久久国产二区| 亚洲精品无码久久久久AV麻豆| 国产女人aaa级久久久级| 丁香五月综合久久激情| 国产福利电影一区二区三区,免费久久久久久久精 | 久久福利青草精品资源站免费| 精品无码久久久久国产| www久久久天天com| 久久精品国产精品亚洲精品 | 久久综合狠狠综合久久综合88| 久久国产乱子伦免费精品|