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


            May the force be with you!
            posts - 52,  comments - 33,  trackbacks - 0

            下午比賽做得有點(diǎn)挫。被安排寫(xiě)G題的解題報(bào)告,這里順便貼上來(lái)。
                                                                 ——littlekid

             

            題目描述:

            Problem G - 數(shù)制轉(zhuǎn)換】

            Description
              
            有一種數(shù)制的基數(shù)是三,權(quán)值可以取-1,0,1,并且分別用符號(hào)-.0.1 表示。這種數(shù)值的
            101
            便表示十進(jìn)制的10,即1×32 + 0×31 + 1×30 = 10,又如這種數(shù)制的-0 表示十進(jìn)制
            -3,即-1×31 + 0×30 = -3。標(biāo)稱(chēng)要求把給定的有符號(hào)證書(shū)轉(zhuǎn)換為新數(shù)制的數(shù),該數(shù)的
            前面不能有多余的0,入10 的新數(shù)制表示是101,則不要輸出乘0101。
            輸入格式
              
            數(shù)據(jù)第一行的數(shù)字T 表示輸入數(shù)據(jù)有T 組,接下來(lái)的T 行每行有一個(gè)整數(shù)N(32 位整型
            可表示范圍內(nèi)),整數(shù)內(nèi)不會(huì)有其他分隔符。
            輸出格式
               
            對(duì)輸入的每一個(gè)數(shù)字輸出一行,該行是輸入行整數(shù)的新數(shù)制表示。
            Sample Input
            2
            10
            -3
            Sample Output
            101
            -0

            【題目分析】
               
            對(duì)于每一位,他有一個(gè)權(quán)值,為這一位乘以3^(i-1)。本題關(guān)鍵點(diǎn)就在于要從后面的位開(kāi)
            始取。如果能想到這里題目就搞定了——實(shí)現(xiàn)起來(lái)比較簡(jiǎn)單,還有一點(diǎn)就是負(fù)數(shù)問(wèn)題,很快
            就能想到每位取反。

            【解題思路】
              
            這個(gè)題目解法很簡(jiǎn)單:首先是正數(shù)的情況,對(duì)N進(jìn)行取余,如果得1則這一位為1,為0自然
            0,如果取模得2,則進(jìn)行轉(zhuǎn)換,當(dāng)前位?。?span lang="EN-US">1
            。對(duì)于負(fù)數(shù),轉(zhuǎn)化為相反數(shù)處理,然后每位取
            反,相反數(shù)得相反數(shù)就是這個(gè)數(shù)本身。

            【樣例程序】



             1 /*********************************************************************
             2 Author: littlekid
             3 Created Time: 2008-1-20 15:28:47
             4 Problem Source: 
             5 Description:
             6 ********************************************************************/
             7 # include<stdio.h>
             8 
             9 int main()
            10 {
            11     int t; scanf("%d"&t);
            12     int tmp, k, cur, n;
            13     int a[20], tag;
            14     
            15     while (t --)
            16     {
            17         scanf("%d"&n);
            18         tmp = n;
            19         k = 0;
            20         if (n == 0////這里開(kāi)始未考慮到,WA了一次 !!!!!
            21         {
            22             printf("0\n");
            23             continue;
            24         }
            25         
            26         tag = 1;
            27         if (n < 0//標(biāo)記負(fù)數(shù)
            28         {
            29             n *= -1;
            30             tag = -1;
            31         }
            32         //主要過(guò)程:對(duì)n不斷除3并求余數(shù)
            33         while ( n != 0 )
            34         {
            35             tmp = n%3;
            36             if (tmp == 2)
            37             {
            38                 tmp = -1;
            39                 n += 2;
            40             }
            41             else
            42             {
            43                 n -= tmp;
            44             }
            45             a[k] = tmp*tag;
            46             n /= 3;
            47                k ++;
            48         }
            49         //輸出結(jié)果
            50         for (int i = k-1; i >= 0; i --)
            51         {
            52             switch(a[i])
            53             {
            54                 case 0:printf("0");
            55                     break;
            56                 case -1:printf("-");
            57                     break;
            58                 case 1:printf("1");
            59                     break;
            60                 default:printf("ERROR\n");
            61             }
            62         }
            63         printf("\n");
            64     }
            65     return 0;
            66 }
            67 

            posted on 2008-01-20 19:58 R2 閱讀(297) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): Problem Solving
            你是第 free hit counter 位訪(fǎng)客




            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿(4)

            隨筆分類(lèi)(54)

            隨筆檔案(52)

            文章檔案(1)

            ACM/ICPC

            技術(shù)綜合

            最新隨筆

            搜索

            •  

            積分與排名

            • 積分 - 63676
            • 排名 - 358

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            一本色道久久综合亚洲精品| 日韩欧美亚洲综合久久| 九九热久久免费视频| 国产成人精品久久亚洲| 成人综合久久精品色婷婷| 亚洲精品无码久久久久| 久久国产乱子伦精品免费午夜| 2021最新久久久视精品爱 | 成人国内精品久久久久一区| 久久亚洲精品人成综合网| 国产精品成人精品久久久| 国产精品久久久天天影视| 欧美激情精品久久久久久| 久久亚洲精品人成综合网| 一本色道久久综合狠狠躁篇 | 亚洲中文久久精品无码ww16| 久久久久综合中文字幕| 久久亚洲视频| 久久精品国产精品亚洲精品 | 久久久一本精品99久久精品88| 国产激情久久久久久熟女老人 | 欧美亚洲另类久久综合| 色婷婷久久久SWAG精品| 7777精品伊人久久久大香线蕉 | 国产精品久久久久久| 蜜臀av性久久久久蜜臀aⅴ| 久久人人爽人爽人人爽av| 免费精品99久久国产综合精品| 日本欧美久久久久免费播放网| 一本色道久久88综合日韩精品 | 97精品依人久久久大香线蕉97| 久久精品国产秦先生| 精品999久久久久久中文字幕| 久久久久亚洲av综合波多野结衣| 久久久久久久久久免免费精品| 国内精品久久久久久久coent| 精品国产一区二区三区久久久狼 | 国产美女久久精品香蕉69| 久久免费高清视频| 精品久久人人爽天天玩人人妻| 精品无码久久久久久久久久|