• <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>
            隨筆-21  評論-10  文章-21  trackbacks-0
               沒有通法,沒有萬金油.
               記得partychen說過acm真的很有意思,每一道題都不一樣.今天這道題觀察出規律后,需要用大數,于是用java寫了一遍,TLE,不知道原因,一直交,一直超時,一開始懷疑java的輸出不能用Scanner, 改了BufferReader還是超時,最后用C++的大數模板還是超時,卻是一直沒想到它只要除2,只要減1
              
             1 #include<stdio.h>
             2 #include<string.h>
             3 
             4 #define maxlen 2005
             5 struct HP {int len,s[maxlen];};
             6 
             7 void PrintHP(HP x){
             8     for(int i=x.len;i>=1;i--) printf("%d",x.s[i]);
             9 }
            10 
            11 void Str2HP(const char* s ,HP &x)
            12 {
            13     x.len=strlen(s);
            14     for(int i=1;i<=x.len;i++)
            15         x.s[i]=s[x.len-i]-'0';
            16 }
            17 
            18 void dell(HP & a){
            19     int i;
            20     for(i = 1; i <= a.len; i++)
            21         if(a.s[i]==0)a.s[i] = 9else break;
            22     a.s[i]--;
            23     if(a.s[a.len]==0)a.len--;
            24 }
            25 
            26 
            27 bool div2(HP & a){
            28    int i; a.s[0= 0;
            29    for(i = a.len; i >= 1; i--)
            30    {
            31        a.s[i-1+= 10*(a.s[i]%2);
            32        a.s[i] /= 2;
            33    }
            34    if(a.s[a.len]==0)a.len--;
            35    return a.s[0]==10;
            36 }
            37 
            38 
            39 char num[maxlen];
            40 
            41 int main(){
            42     HP a;
            43     int T;
            44     for( scanf("%d"&T), getchar(); T > 0; T--){
            45         gets(num);
            46         gets(num);
            47         Str2HP(num,a);
            48         if( div2(a) )
            49             PrintHP(a);
            50         else{
            51             HP b = a; 
            52             if(div2(a) ){
            53                 dell(b); dell(b);
            54                 PrintHP(b);
            55             }
            56             else{
            57                 dell(b);
            58                 PrintHP(b);
            59             }
            60         }
            61         printf("\n");
            62         if( T > 1)printf("\n");
            63     }
            64     return 0;
            65 }
            66 
            67 /*
            68 2
            69 
            70 7
            71 
            72 6
            73 
            74 */
            75 


            posted on 2009-09-10 20:02 wangzhihao 閱讀(168) 評論(0)  編輯 收藏 引用 所屬分類: math
            97精品伊人久久久大香线蕉| 日韩电影久久久被窝网| 久久久精品久久久久久 | 青青草国产精品久久| 99久久中文字幕| 久久精品国产一区二区三区| 中文成人无码精品久久久不卡| 伊人久久大香线蕉av不变影院| 精品久久久久久中文字幕| 欧洲性大片xxxxx久久久| 日产精品久久久久久久| 国产精品VIDEOSSEX久久发布 | www.久久热| 中文字幕无码av激情不卡久久| 久久精品国产亚洲av影院| 久久久精品国产Sm最大网站| 国产精品国色综合久久| 伊人久久五月天| 18岁日韩内射颜射午夜久久成人| 99久久精品国产一区二区 | 日本高清无卡码一区二区久久| 久久夜色精品国产噜噜噜亚洲AV| 精品久久久久久无码中文字幕| 久久精品无码午夜福利理论片| 欧美日韩久久中文字幕| 狠狠色综合网站久久久久久久| 久久精品国产亚洲av日韩| 久久亚洲sm情趣捆绑调教| 久久久久亚洲AV无码专区桃色| 91精品国产乱码久久久久久| 久久精品夜夜夜夜夜久久| 国色天香久久久久久久小说| 最新久久免费视频| 亚洲国产成人精品91久久久 | 国产精品成人久久久| 久久亚洲AV无码西西人体| 9999国产精品欧美久久久久久| 久久99精品国产麻豆| 老色鬼久久亚洲AV综合| 亚洲精品美女久久久久99| 亚洲欧美一区二区三区久久|