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

            來(lái)自于《編碼》

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

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

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

             


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

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

            字母都是按照大寫(xiě)處理的。
            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.

            這就是莫爾斯電碼。
            實(shí)現(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 閱讀(497) 評(píng)論(0)  編輯 收藏 引用

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


            狠狠久久综合伊人不卡| 热久久最新网站获取| 久久国产精品成人影院| 久久亚洲精精品中文字幕| 99久久99这里只有免费费精品| 麻豆精品久久久一区二区| 久久久久一本毛久久久| 精品伊人久久久| 久久久91精品国产一区二区三区| 日本久久中文字幕| 久久这里只有精品久久| 久久99精品国产麻豆宅宅| 91精品国产91热久久久久福利| 久久天天躁狠狠躁夜夜2020| 久久精品99久久香蕉国产色戒| 久久精品亚洲乱码伦伦中文 | 久久天天躁狠狠躁夜夜2020老熟妇| 2021国内精品久久久久久影院| 国产精品久久久久无码av| 伊人色综合久久天天人守人婷| 国产成人久久AV免费| 日本五月天婷久久网站| 久久久精品国产Sm最大网站| 久久99久久99小草精品免视看| 综合人妻久久一区二区精品| 欧美国产成人久久精品| 久久久久99精品成人片牛牛影视 | 香蕉久久久久久狠狠色| 国产精品无码久久久久| 国产亚洲欧美成人久久片| 久久久噜噜噜久久熟女AA片| 伊人情人综合成人久久网小说| 久久久久久毛片免费看| 99久久精品国产一区二区| 欧美伊香蕉久久综合类网站| 99久久婷婷国产综合亚洲| 久久99国产精品一区二区| jizzjizz国产精品久久| 精品无码久久久久久午夜| 久久久青草久久久青草| 狠狠久久综合|