• <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...
            基本原理就是用的二進(jìn)制方式,用兩種形式,即短信號和長信號,分別用兩種形式表示
            可以是
            點和劃
            也可以是
            0 和 1
            | 和 -
            a 和 b
            等。

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

            莫爾斯已經(jīng)給出了各個符號的編碼,例如 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 _    ..--.-

             


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

            在針對這個編碼進(jìn)行解碼得到:
            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.

            這就是莫爾斯電碼。
            實現(xiàn):

             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精品国产91久久麻豆| 亚洲成色999久久网站| 中文成人无码精品久久久不卡| 欧美亚洲色综久久精品国产| 99久久国产免费福利| 一本色道久久88—综合亚洲精品| 久久精品无码一区二区三区| 久久久久久精品无码人妻| 久久国产成人精品麻豆| 精品久久久中文字幕人妻| 精品久久久久久无码中文字幕| 欧洲人妻丰满av无码久久不卡| 日韩电影久久久被窝网| 色综合久久精品中文字幕首页 | 77777亚洲午夜久久多喷| 99久久精品国产一区二区蜜芽| 亚洲国产精品无码久久久蜜芽| 草草久久久无码国产专区| 97久久久精品综合88久久| 亚洲香蕉网久久综合影视| 中文字幕精品无码久久久久久3D日动漫| 狠狠色丁香婷综合久久| 久久亚洲AV成人无码国产| 亚洲精品国精品久久99热一| 狠狠色丁香久久婷婷综合蜜芽五月| 久久亚洲精品中文字幕三区| 国产精品久久久久影院嫩草| 久久久久99精品成人片直播| 亚洲AV无码一区东京热久久| 久久AV高潮AV无码AV| 久久九九兔免费精品6| 久久99精品国产麻豆宅宅| 国产成人精品综合久久久| 久久99精品国产麻豆宅宅| 久久久久亚洲AV成人片| 久久国产欧美日韩精品| 久久精品九九亚洲精品天堂| 91精品久久久久久无码|