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

            來自于《編碼》

            電報中用的莫爾斯編碼,對電報一直感到很神奇,dita data...
            基本原理就是用的二進制方式,用兩種形式,即短信號和長信號,分別用兩種形式表示
            可以是
            點和劃
            也可以是
            0 和 1
            | 和 -
            a 和 b
            等。

            一種編碼最重要的是如何對每個符號進行編碼,這里需要考慮
            編碼的效率,哪些是常用的?哪些是非常用的?
            編碼的形式,前綴碼?
            如何編碼,編碼的實現?
            如何解碼,解碼的實現?

            莫爾斯已經給出了各個符號的編碼,例如 morseCode.txt:

             1 A    .-
             2 B    -
             3 C    -.-.
             4 D    -..
             5 E    .
             6 F    ..-.
             7 G    --.
             8 H    .
             9 I    ..
            10 J    .---
            11 K    -.-
            12 L    .-..
            13 M    --
            14 N    -.
            15 O    ---
            16 P    .--.
            17 Q    --.-
            18 R    .-.
            19 S    
            20 T    -
            21 U    ..-
            22 V    -
            23 W    .--
            24 X    -..-
            25 Y    -.--
            26 Z    --..
            27 1    .----
            28 2    ..---
            29 3    --
            30 4    .-
            31 5    ..
            32 6    -.
            33 7    --
            34 8    ---..
            35 9    ----.
            36 10    -----
            37 .    .-.-.-
            38 ,    --..--
            39 ?    ..--..
            40 :    ---
            41 ;    -.-.-.
            42 -    -.-
            43 /    -..-.
            44 "    .-..-.
            45 '    .----.
            46 (    -.--.
            47 )    -.--.-
            48 =    --
            49 +    .-.-.
            50 $    -..-
            51 |    .-.-..
            52 _    ..--.-

             


            這樣針對一句話,可以進行編碼了,例如這句話:
            Before the police moved in, they set up a battery of klieg lights and aimed them into the park.
            編碼得到:
            -... . ..-. --- .-. .   - .... .        .--. --- .-.. .. -.-. .         -- --- .
            ..- . -..       .. -. --..--    - .... . -.--   ... . -         ..- .--.
            .-      -... .- - - . .-. -.--  --- ..-.        -.- .-.. .. . --.       .-.. ..
            --. .... - ...  .- -. -..       .- .. -- . -..  - .... . --     .. -. - ---
            - .... .        .--. .- .-. -.- .-.-.-

            在針對這個編碼進行解碼得到:
            BEFORE THE POLICE MOVED IN, THEY SET UP A BATTERY OF KLIEG LIGHTS AND AIMED THEM
             INTO THE PARK.

            字母都是按照大寫處理的。
            Before the police moved in, they set up a battery of klieg lights and aimed them
             into the park.
            -... . ..-. --- .-. .   - .... .        .--. --- .-.. .. -.-. .         -- --- .
            ..- . -..       .. -. --..--    - .... . -.--   ... . -         ..- .--.
            .-      -... .- - - . .-. -.--  --- ..-.        -.- .-.. .. . --.       .-.. ..
            --. .... - ...  .- -. -..       .- .. -- . -..  - .... . --     .. -. - ---
            - .... .        .--. .- .-. -.- .-.-.-
            BEFORE THE POLICE MOVED IN, THEY SET UP A BATTERY OF KLIEG LIGHTS AND AIMED THEM
             INTO THE PARK.

            這就是莫爾斯電碼。
            實現:

             1 #include <iostream>
             2 #include <fstream>
             3 #include <string>
             4 #include <map>
             5 #include <cctype>
             6 using namespace std;
             7 
             8 string encode(const string& sentence, const map<charstring>& encoding)
             9 {
            10     string tmp;
            11     for (string::size_type i = 0; i != sentence.size(); ++i)
            12     {
            13         map<charstring>::const_iterator cit = encoding.find(static_cast<char>(toupper(sentence[i])));
            14         if (cit != encoding.end())
            15         {
            16             tmp += cit->second;
            17             tmp += ' ';
            18         }
            19         else
            20         {
            21             tmp += '\t';
            22         }
            23     }
            24     return tmp;
            25 }
            26 
            27 string decode(const string& mc, const map<stringchar>& decoding)
            28 {
            29     string tmp, m;
            30     for (string::size_type i = 0; i != mc.size(); ++i)
            31     {
            32         if (mc[i] == ' ')
            33         {
            34             map<stringchar>::const_iterator cit = decoding.find(m);
            35             if (cit != decoding.end())
            36             {
            37                 tmp += cit->second;
            38             }
            39             m.clear();
            40         }
            41         else if (mc[i] == '\t')
            42         {
            43             tmp += ' ';
            44         }
            45         else
            46         {
            47             m += mc[i];
            48         }
            49     }
            50     return tmp;
            51 }
            52 
            53 int main()
            54 {
            55     ifstream fin("morseCode.txt");
            56     if (!fin)
            57     {
            58         cerr << "File error!" << endl;
            59         return 1;
            60     }
            61     char a;
            62     string b;
            63     map<charstring> encoding;
            64     map<stringchar> decoding;
            65     while (fin >> a >> b)
            66     {
            67         encoding[a] = b;
            68         decoding[b] = a;
            69     }
            70     fin.close();
            71     string sentence;
            72     string mc;
            73     while (getline(cin, sentence))
            74     {
            75         mc = encode(sentence, encoding);
            76         cout << mc << endl;
            77         sentence = decode(mc, decoding);
            78         cout << sentence << endl;
            79     }
            80     return 0;
            81 }
            82 


            posted on 2011-11-15 17:13 unixfy 閱讀(495) 評論(0)  編輯 收藏 引用
            青青国产成人久久91网| 久久亚洲熟女cc98cm| 精品久久久无码人妻中文字幕豆芽| 一本色道久久综合狠狠躁篇 | 国产精品九九九久久九九| 久久精品国产亚洲AV影院| 国产情侣久久久久aⅴ免费| 久久久久女人精品毛片| 国产成人精品久久亚洲高清不卡| 国内精品久久久久久久涩爱| 久久综合成人网| 久久青草国产精品一区| 丁香色欲久久久久久综合网| 国内精品久久久久久99| 国产午夜精品久久久久九九电影 | 久久婷婷五月综合成人D啪 | 99精品伊人久久久大香线蕉| 亚洲国产成人久久综合野外| 99久久精品国产高清一区二区 | 精品免费久久久久国产一区| 国产精品99久久久精品无码| 青青热久久综合网伊人| 久久人人爽人人爽人人AV| 国内精品久久久久久99| 久久人人爽人人爽人人爽| 久久亚洲欧洲国产综合| 51久久夜色精品国产| 91精品国产综合久久婷婷| 亚洲av成人无码久久精品| 欧美精品国产综合久久| 性高朝久久久久久久久久| 久久高清一级毛片| 精品久久人人爽天天玩人人妻| 精品综合久久久久久888蜜芽| 亚洲国产香蕉人人爽成AV片久久 | 亚洲中文字幕无码久久综合网| 久久久久国产一级毛片高清板| 亚洲国产精品一区二区久久| 国产精品久久免费| 色综合久久综精品| 国产精品视频久久|