• <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 - 183,  comments - 10,  trackbacks - 0
            http://blog.csdn.net/v_JULY_v
            一個(gè)算法的博客

            幾個(gè)算法題目

            1.
            實(shí)現(xiàn)過程中參考了網(wǎng)上別人的博客,主要思想是利用一個(gè)輔助棧記錄 min 的索引。

             1 #include <iostream>
             2 #include <ctime>
             3 #include <cassert>
             4 using namespace std;
             5 
             6 class MinStack
             7 {
             8 private:
             9     int stack[100];
            10     int p;
            11     int minstack[100];
            12     int q;
            13 public:
            14     MinStack() : p(0), q(0) {}
            15     bool empty()
            16     {
            17         return p == 0;
            18     }
            19     bool minEmpty()
            20     {
            21         return q == 0;
            22     }
            23     void push(int i)
            24     {
            25         stack[p++= i;
            26         if (minEmpty())
            27         {
            28             minstack[q++= p - 1;
            29         }
            30         else
            31         {
            32             if (i <= stack[minTop()])
            33             {
            34                 minstack[q++= p - 1;
            35             }
            36         }
            37     }
            38     void pop()
            39     {
            40         assert(!empty());
            41         if (top() == stack[minTop()])
            42         {
            43             minPop();
            44         }
            45         --p;
            46     }
            47     int min()
            48     {
            49         assert(!empty());
            50         return stack[minTop()];
            51     }
            52     void minPop()
            53     {
            54         assert(!minEmpty());
            55         --q;
            56     }
            57     int top()
            58     {
            59         assert(!empty());
            60         return stack[p - 1];
            61     }
            62     int minTop()
            63     {
            64         assert(!minEmpty());
            65         return minstack[q - 1];
            66     }
            67 };
            68 
            69 int main()
            70 {
            71     MinStack ms;
            72     srand(time(0));
            73     for (int i = 0; i < 10++i)
            74     {
            75         int n = rand() % 100;
            76         ms.push(n);
            77     }
            78     while (!ms.empty())
            79     {
            80         cout << ms.top() << '\t' << ms.min() << endl;
            81         ms.pop();
            82     }
            83     return 0;
            84 }

             


            2.
             1 /*
             2  *
             3  *先統(tǒng)計(jì)所有查詢的次數(shù),所有查詢有 300 萬個(gè),255 * 300 * 10000B = 765 MB,可以存入內(nèi)存。這里使用 STL 中的 map。所得時(shí)間復(fù)雜度為 O(NlogM),N 為所有的查詢,包括重復(fù)的,M 為不重復(fù)的查詢。更好的方法是用散列。
             4  *
             5  *然后遍歷 map,維護(hù)一個(gè)大小為 10 的集合,在遍歷 map 時(shí),比較當(dāng)前查詢的出現(xiàn)次數(shù)與集合中出現(xiàn)次數(shù)最小的查詢的出現(xiàn)此時(shí)比較,如果大于,將當(dāng)前查詢替換到集合中。
             6  *這里的集合還是用的 map,時(shí)間復(fù)雜度為 O(MlogK),這里 K = 10。
             7  *
             8  */
             9 
            10 #include <iostream>
            11 #include <fstream>
            12 #include <map>
            13 #include <string>
            14 using namespace std;
            15 
            16 void statistics(map<stringint>& data, const string& query)
            17 {
            18     ++data[query];
            19 }
            20 
            21 void findTopK(multimap<intstring>& topK, int k, const map<stringint>& data)
            22 {
            23     topK.clear();
            24     for (map<stringint>::const_iterator cit = data.begin(); cit != data.end(); ++cit)
            25     {
            26         if (topK.size() < k)
            27         {
            28             topK.insert(make_pair(cit->second, cit->first));
            29         }
            30         else
            31         {
            32             if (cit->second > topK.begin()->first)
            33             {
            34                 topK.erase(topK.begin());
            35                 topK.insert(make_pair(cit->second, cit->first));
            36             }
            37         }
            38     }
            39 }
            40 
            41 int main()
            42 {
            43     ifstream fin("queryfile.txt");
            44     map<stringint> data;
            45     multimap<intstring> top10;
            46     string query;
            47     while (getline(fin, query))
            48     {
            49         statistics(data, query);
            50     }
            51     findTopK(top10, 10, data);
            52     for (multimap<intstring>::const_reverse_iterator cit = top10.rbegin(); cit != top10.rend(); ++cit)
            53     {
            54         cout << cit->second << '\t' << cit->first << endl;
            55     }
            56 
            57     return 0;
            58 }

            3.
             1 #include <iostream>
             2 #include <string>
             3 using namespace std;
             4 
             5 char solve(const string& s)
             6 {
             7     static int times[26= {0};
             8     memset(times, 0sizeof (times));
             9     for (size_t i = 0; i < s.size(); ++i)
            10     {
            11         ++times[s[i] - 'a'];
            12     }
            13     for (size_t i = 0; i < s.size(); ++i)
            14     {
            15         if (times[s[i] - 'a'== 1)
            16         {
            17             return s[i];
            18         }
            19     }
            20     return 0;
            21 }
            22 
            23 int main()
            24 {
            25     string s = "abaccdeff";
            26     cout << solve(s) << endl;
            27     return 0;
            28 }

            posted on 2011-06-25 16:44 unixfy 閱讀(90) 評(píng)論(0)  編輯 收藏 引用

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


            奇米影视7777久久精品人人爽| 狠狠色丁香久久综合婷婷| 国产精品久久一区二区三区| 久久SE精品一区二区| 亚洲国产精品成人久久蜜臀| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久人人爽人人爽人人爽| 日本久久中文字幕| 久久精品国产亚洲麻豆| 久久精品国产亚洲一区二区| 久久无码中文字幕东京热| 狠狠狠色丁香婷婷综合久久五月| 久久人人爽人人澡人人高潮AV| 久久午夜无码鲁丝片| 久久婷婷人人澡人人| 成人妇女免费播放久久久| 国产成人精品久久一区二区三区av | 无遮挡粉嫩小泬久久久久久久| 国产 亚洲 欧美 另类 久久| 色综合久久中文字幕无码| 久久夜色精品国产| 国产精品99久久久久久www| 久久国产高潮流白浆免费观看| 久久久久久久久66精品片| 国产精品综合久久第一页| 久久久久人妻一区二区三区vr| 久久精品无码午夜福利理论片| 久久久久久久免费视频| 狠狠综合久久综合中文88| 久久精品国产免费| 久久99精品国产自在现线小黄鸭| 久久婷婷五月综合国产尤物app| 久久夜色撩人精品国产| 久久毛片免费看一区二区三区| 精品无码人妻久久久久久| AAA级久久久精品无码区| 久久久久久狠狠丁香| 亚洲综合精品香蕉久久网97| 大美女久久久久久j久久| 国产精品成人久久久久久久| 久久www免费人成看国产片|