• <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 閱讀(162) 評論(0)  編輯 收藏 引用 所屬分類: math
            国内精品久久久久影院薰衣草| 亚洲av日韩精品久久久久久a| 99精品国产在热久久| 亚洲伊人久久精品影院| 色欲久久久天天天综合网 | 久久久黄色大片| 久久婷婷人人澡人人| 性做久久久久久久久老女人| 久久精品国产亚洲av麻豆图片| 亚洲国产精品无码久久98| 久久99精品久久久久久hb无码| 久久99精品久久久久久| 91精品国产91久久久久久青草| 久久se精品一区精品二区国产| 久久国产成人精品麻豆| 精品久久久久久久无码| 99久久99这里只有免费的精品| 久久99精品国产| 久久99精品久久久久久野外| 思思久久精品在热线热| 一本久久知道综合久久| 亚洲国产精久久久久久久| 亚洲&#228;v永久无码精品天堂久久| 中文字幕无码av激情不卡久久| 久久精品国产精品亚洲精品| 91精品国产91久久久久久青草| 亚洲精品tv久久久久| 东京热TOKYO综合久久精品| 久久久久无码精品国产app| 久久精品国产亚洲AV无码娇色| 久久久久国产一级毛片高清板| 久久中文骚妇内射| 久久久久一本毛久久久| 久久99国产亚洲高清观看首页| 一本久道久久综合狠狠爱| 久久久久亚洲AV成人网| 欧美牲交A欧牲交aⅴ久久| 久久夜色撩人精品国产小说| 久久国产色AV免费看| 色综合久久天天综线观看| 99久久精品久久久久久清纯|