• <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
            999久久久免费国产精品播放| 久久九九久精品国产| 老司机午夜网站国内精品久久久久久久久 | 免费一级欧美大片久久网| 无码乱码观看精品久久| 伊人久久大香线蕉av一区| 日本欧美久久久久免费播放网| 久久综合欧美成人| 久久精品视频一| 久久精品国产精品青草app| 久久精品国产福利国产琪琪| 色偷偷久久一区二区三区| 国产精品一区二区久久精品无码| 久久经典免费视频| 久久精品无码一区二区三区| 久久人人爽人人爽人人片AV不 | 精品免费tv久久久久久久| 无码国内精品久久人妻麻豆按摩| 97r久久精品国产99国产精| 亚洲午夜久久久| 国产精品九九久久免费视频| 无码超乳爆乳中文字幕久久| 久久久久久国产a免费观看不卡| 国内精品伊人久久久久AV影院| 久久久久久久免费视频| 久久强奷乱码老熟女网站| 久久精品视频网| 老司机国内精品久久久久| 婷婷综合久久中文字幕蜜桃三电影| 99久久精品无码一区二区毛片 | 久久本道伊人久久| 2022年国产精品久久久久| 久久这里只有精品18| 国产成人精品综合久久久久| 国产精品久久久久久久app| 久久99精品久久久久久水蜜桃| 久久精品国产久精国产| 久久er国产精品免费观看2| 色综合久久综合网观看| 色噜噜狠狠先锋影音久久| 国产真实乱对白精彩久久|