• <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>

            The Fourth Dimension Space

            枯葉北風(fēng)寒,忽然年以殘,念往昔,語默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢令

            集訓(xùn)專題訓(xùn)練1::搜索 福州大學(xué)全國邀請賽 Divisibility by Thirty-six 狀態(tài)空間搜索

            和整除45差不多,枚舉后兩位。復(fù)雜度應(yīng)該是25*1000 ,但很奇怪跑了390MS...可能中間計算常數(shù)時間比較大。
            再說幾句,這題輸出相當惡心啊,我挑了1個小時才大致理出輸出的邏輯順序,也許還不一定完全正確呢。這題還有優(yōu)化的可能。
            請各路神牛指點
            #include<iostream>
            #include
            <algorithm>
            #include
            <cmath>
            #include
            <cstring>
            using namespace std;

            struct node
            {
                
            int num[10];
                
            int r;
            }
            q[1010];

            int dir[25][2]=
            {
                
            {0,0},
                
            {0,4},
                
            {0,8},
                
            {1,2},
                
            {1,6},
                
            {2,0},
                
            {2,4},
                
            {2,8},
                
            {3,2},
                
            {3,6},
                
            {4,0},
                
            {4,4},
                
            {4,8},
                
            {5,2},
                
            {5,6},
                
            {6,0},
                
            {6,4},
                
            {6,8},
                
            {7,2},
                
            {7,6},
                
            {8,0},
                
            {8,4},
                
            {8,8},
                
            {9,2},
                
            {8,6}
            }
            ;

            int getd(int num[])//統(tǒng)計這個大數(shù)的位數(shù)
            {
                
            int ans=0;
                
            for(int i=0;i<10;i++)
                
            {
                    ans
            +=num[i];
                }

                
            return ans;
            }

            int getsum(int num[])//統(tǒng)計這個大數(shù)每位之和
            {

                
            int ans=0;
                
            for(int i=0;i<10;i++)
                
            {
                    ans
            +=num[i]*i;
                }

                
            return ans;
            }



            int v[11][11][11];//hash判重
            int orinum[10];//初始大數(shù)
            int num[10];
            int flagnum[10];
            char s[2000];//字符串
            int t;


            int ansnum[10];//最終結(jié)果,有中間處理,注意加0加5的情況
            int ansflag;

            int haszero;//有0嗎
            int cmp(int ansnum[],int num[])
            {

                
            int len1=getd(ansnum);
                
            int len2=getd(num);

                
            //特別處理一下兩個數(shù)是全0的情況
                if(getsum(ansnum)==0&&getsum(num)==0)
                    
            return 0;
                
            else if(getsum(ansnum)==0&&getsum(num)!=0)
                    
            return -1;
                
            else if(getsum(ansnum)!=0&&getsum(num)==0)
                    
            return 1;
                
            //end

                
            if(len1>len2)
                    
            return 1;
                
            else if(len1<len2)
                    
            return -1;
                
            else
                
            {
                    
            int i;
                    
            for(i=9;i>=1;i--)
                    
            {
                        
            if(ansnum[i]>num[i])
                            
            return 1;
                        
            else if(ansnum[i]<num[i])
                            
            return -1;
                    }

                    
            return 0;
                }

            }


            void copy(int t[],int s[])//copy s里面的東西到t 
            {
                
            int i;
                
            for(i=0;i<=9;i++)
                    t[i]
            =s[i];
            }



            void output(int num[])//沒有加回車,注意預(yù)先去掉的數(shù)字
            {

                
            for(int i=9;i>=0;i--)
                
            {
                    
            if(num[i]!=0)
                        
            for(int j=1;j<=num[i];j++)
                            printf(
            "%d",i);
                }

            }


            bool check(int a,int b)//判斷字符串中是否有a,b
            {

                
            int ma=0;
                
            int len=strlen(s+1);
                
            for(int i=1;i<=len;i++)
                    
            if(s[i]-'0'==a)
                        ma
            =i;
                
            if(ma==0)
                    
            return false;
                
            for(int i=1;i<=len;i++)
                
            {
                    
            if(i==ma)
                        
            continue;
                    
            if(s[i]-'0'==b)
                        
            return true;
                }

                
            return false;
            }



            void zerozero()
            {
                
            int len=strlen(s+1);
                
            for(int i=1;i<=len;i++)
                    
            if(s[i]-'0'==0)
                    
            {
                        haszero
            =1;
                        
            return;
                    }


                haszero
            =0;
            }


            bool allzero()
            {

                
            int i;
                
            for(i=1;i<10;i++)
                    
            if(ansnum[i]!=0)
                        
            return false;
                
            return true;
            }

            int main()
            {
                
            int t;
                scanf(
            "%d",&t);
                
            int ca=0;
                
            while(t--)
                
            {    
                    ca
            ++;
                    scanf(
            "%s",s+1);
                    
            int last1=-1;
                    
            int last2=-1;
                    memset(ansnum,
            0,sizeof(ansnum));
                    memset(orinum,
            0,sizeof(orinum));
                    zerozero();
                    
                    
            int len=strlen(s+1);
                    
            for(int i=1;i<=len;i++)
                    
            {
                        orinum[s[i]
            -'0']++;
                    }


                    
            for(int k=0;k<25;k++)
                    
            {
                        
            if(check(dir[k][0],dir[k][1])==false)
                            
            continue;
                            
                        
                        memset(v,
            0,sizeof(v));
                        memset(num,
            0,sizeof(num));
                        copy(num,orinum);
                        
            int l,r;
                        l
            =r=1;
                        copy(q[
            1].num,num);
                        q[
            1].num[dir[k][0]]--;
                        q[
            1].num[dir[k][1]]--;
                        
            int tem=getsum(q[1].num);
                        q[
            1].r=tem%9;
                        tem
            %=9;
                        v[tem][tem][
            0]=1;
                        
            int realreminder=((-dir[k][0]-dir[k][1])%9+9)%9;
                        
            while(l<=r)
                        
            {
                            
            if(cmp(q[l].num,ansnum)>=0&&q[l].r==realreminder)
                            
            {
                                
            //ansflag=1;
                                last1=dir[k][0];
                                last2
            =dir[k][1];
                                copy(ansnum,q[l].num);
                            }



                            
            for(int i=1;i<10;i++)
                            
            {

                                
            int nr=(q[l].r-i+9)%9;
                                
            if(q[l].num[i]>0&&v[q[l].r][nr][i]==0)
                                
            {
                                    r
            ++;
                                    copy(q[r].num,q[l].num);
                                    q[r].num[i]
            --;
                                    q[r].r
            =nr;
                                    v[q[l].r][nr][i]
            =1;
                                }

                            }

                            l
            ++;
                        }

                    }


                    
            if(last1==-1&&haszero)
                    
            {
                        printf(
            "Case %d: ",ca);
                        printf(
            "0\n");
                    }

                    
            else if(last1==-1)
                        printf(
            "Case %d: impossible\n",ca);

                    
            else if(last1==last2&&last1==0&&allzero())
                    
            {
                        printf(
            "Case %d: ",ca);
                        printf(
            "0\n");
                    }


                        
                    
            else if(allzero())
                    
            {
                        printf(
            "Case %d: ",ca);
                        printf(
            "%d%d\n",last1,last2);
                    
                    }


                    
            else if(!allzero())
                    
            {
                        printf(
            "Case %d: ",ca);
                        output(ansnum);
                        printf(
            "%d%d\n",last1,last2);
                    }

                


                }

                
                
            return 0;
            }


            代碼依舊非常猥瑣。。。

            posted on 2010-07-03 17:30 abilitytao 閱讀(1549) 評論(1)  編輯 收藏 引用

            評論

            # re: 集訓(xùn)專題訓(xùn)練1::搜索 福州大學(xué)全國邀請賽 Divisibility by Thirty-six 狀態(tài)空間搜索 2010-07-10 09:30 wuyichen

            把函數(shù)都改成內(nèi)聯(lián)的應(yīng)該會快一點  回復(fù)  更多評論   


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久毛片一区二区| 国产精品久久久久久久久久免费| 国产精品久久久久久搜索| 国产午夜精品理论片久久| 久久亚洲AV无码精品色午夜麻豆| 国产精品久久久久久福利69堂| 色天使久久综合网天天| 99久久免费只有精品国产| 人妻少妇久久中文字幕| 久久无码人妻精品一区二区三区| 国产精品美女久久久| 亚洲香蕉网久久综合影视 | 色综合久久久久久久久五月| 婷婷久久综合九色综合98| 亚洲中文久久精品无码ww16| 久久99精品国产麻豆婷婷| 国产精品久久波多野结衣| 久久精品无码一区二区WWW| 国内精品久久久久久久涩爱 | 久久久这里有精品| 久久精品国产99久久久香蕉| 精品久久久久久无码中文字幕一区| 欧美国产成人久久精品| 久久涩综合| 欧美久久综合九色综合| 国产精品久久久久久久久久免费| 久久精品国内一区二区三区| 精品国产乱码久久久久久郑州公司| 人人妻久久人人澡人人爽人人精品 | 久久久久久久综合狠狠综合| 久久青青国产| 久久久青草青青国产亚洲免观| 久久国产免费直播| 精品久久久久久久中文字幕| 久久97久久97精品免视看 | 精品国产一区二区三区久久久狼 | 94久久国产乱子伦精品免费 | 国产精品对白刺激久久久| 精品久久久久久无码中文字幕一区 | 精品久久久一二三区| 久久人人爽人人爽人人片AV高清|