• <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 閱讀(176) 評論(0)  編輯 收藏 引用 所屬分類: math
            99久久精品久久久久久清纯 | 久久99国内精品自在现线| 亚洲国产欧美国产综合久久| 国产精品一区二区久久国产| 久久精品国产亚洲网站| 色播久久人人爽人人爽人人片aV | 久久青青草原国产精品免费 | 7777久久亚洲中文字幕| 久久亚洲天堂| 国产午夜久久影院| 国产成人久久精品一区二区三区| 青青草原综合久久大伊人精品| 久久这里有精品| 久久人妻少妇嫩草AV蜜桃| 久久精品国产亚洲av麻豆色欲 | 久久亚洲精品无码AV红樱桃| 久久久久国产精品麻豆AR影院| 成人久久久观看免费毛片| 国产成人久久精品一区二区三区 | 久久美女网站免费| 久久久噜噜噜www成人网| 亚洲人成电影网站久久| 久久精品国产99国产精品| 色综合久久综精品| 青草影院天堂男人久久| 久久精品一区二区国产| 久久香蕉国产线看观看精品yw| 久久亚洲sm情趣捆绑调教| 婷婷国产天堂久久综合五月| 欧洲国产伦久久久久久久 | 国内精品人妻无码久久久影院 | 久久精品这里热有精品| 99久久精品免费看国产免费| 岛国搬运www久久| 久久精品无码免费不卡| 久久人人超碰精品CAOPOREN| 人妻少妇精品久久| 久久综合色老色| 久久婷婷五月综合色高清| 成人免费网站久久久| 成人国内精品久久久久影院VR|