• <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 閱讀(486) 評論(0)  編輯 收藏 引用
            亚洲精品乱码久久久久久蜜桃图片| 国内精品久久久久久野外| 国产成人精品久久亚洲| 久久国产热这里只有精品| 久久强奷乱码老熟女| 欧美精品乱码99久久蜜桃| 亚洲国产精品无码成人片久久| 久久99精品久久久久婷婷| 国产—久久香蕉国产线看观看| 午夜精品久久久内射近拍高清| 亚洲伊人久久精品影院| 亚洲午夜精品久久久久久人妖| 亚洲AⅤ优女AV综合久久久| 九九99精品久久久久久| 99久久精品免费看国产一区二区三区| 久久久噜噜噜久久熟女AA片 | 久久久久99这里有精品10 | 久久一区二区免费播放| 人妻精品久久无码专区精东影业 | 久久久久亚洲av无码专区喷水| 精品久久久久中文字| 久久精品无码专区免费青青 | 国产福利电影一区二区三区,免费久久久久久久精 | 国产午夜福利精品久久| 无码国产69精品久久久久网站| 久久久久久一区国产精品| 国产精品久久成人影院| 粉嫩小泬无遮挡久久久久久| 久久国产免费直播| 久久精品国产乱子伦| 性做久久久久久久久| 狠狠色综合网站久久久久久久| 天天爽天天爽天天片a久久网| 国产精品久久成人影院| 国产韩国精品一区二区三区久久| 久久精品国产免费观看三人同眠| 中文字幕精品无码久久久久久3D日动漫| 伊人色综合久久| 欧洲性大片xxxxx久久久| 久久性生大片免费观看性| 久久人人爽人人精品视频|