• <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
            久久91亚洲人成电影网站| 国产精品免费久久久久影院| 精品久久久久久国产| 久久99国产综合精品女同| 99久久综合狠狠综合久久| 色综合久久88色综合天天 | 色狠狠久久AV五月综合| 久久噜噜久久久精品66| 久久无码人妻一区二区三区午夜 | 久久精品人妻中文系列| 久久精品中文字幕久久| 看久久久久久a级毛片| 久久精品无码免费不卡| 国产精品99久久免费观看| 久久无码AV一区二区三区| 久久综合丝袜日本网| 久久天天躁狠狠躁夜夜网站| 伊人久久亚洲综合影院| 天天综合久久久网| 久久人人爽人人爽人人AV| 日本久久中文字幕| 国产精品美女久久久久AV福利 | 久久免费视频一区| 久久综合久久综合久久| 91久久精品91久久性色| 国产成人精品久久| 热久久视久久精品18| 欧美激情精品久久久久久久九九九| 99久久成人国产精品免费| 久久久久成人精品无码中文字幕 | 久久99精品久久久久久久不卡| 99久久免费国产精品特黄| 亚洲欧美另类日本久久国产真实乱对白| 青青热久久综合网伊人| 99久久精品免费国产大片| 97久久精品人人做人人爽| 91秦先生久久久久久久| 久久久久婷婷| 久久亚洲国产精品成人AV秋霞| 久久WWW免费人成一看片| 少妇高潮惨叫久久久久久|