青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

The Fourth Dimension Space

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

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

和整除45差不多,枚舉后兩位。復(fù)雜度應(yīng)該是25*1000 ,但很奇怪跑了390MS...可能中間計(jì)算常數(shù)時(shí)間比較大。
再說(shuō)幾句,這題輸出相當(dāng)惡心啊,我挑了1個(gè)小時(shí)才大致理出輸出的邏輯順序,也許還不一定完全正確呢。這題還有優(yōu)化的可能。
請(qǐng)各路神牛指點(diǎn)
#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)計(jì)這個(gè)大數(shù)的位數(shù)
{
    
int ans=0;
    
for(int i=0;i<10;i++)
    
{
        ans
+=num[i];
    }

    
return ans;
}

int getsum(int num[])//統(tǒng)計(jì)這個(gè)大數(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);

    
//特別處理一下兩個(gè)數(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[])//沒(méi)有加回車,注意預(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 閱讀(1564) 評(píng)論(1)  編輯 收藏 引用

評(píng)論

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

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


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


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产日韩欧美一区在线 | 亚洲国产激情| 国产精品久久久久久久久 | 美女在线一区二区| 欧美在线亚洲| 久久高清国产| 欧美不卡视频一区发布| 欧美日本中文字幕| 国产精品久久国产愉拍| 国产嫩草一区二区三区在线观看| 国产精品久久久爽爽爽麻豆色哟哟 | 亚洲美女性视频| 亚洲自拍偷拍网址| 女人天堂亚洲aⅴ在线观看| 欧美国产大片| 欧美亚洲三区| 久久嫩草精品久久久久| 欧美国产日本| 国产嫩草一区二区三区在线观看| 在线观看的日韩av| 亚洲欧美另类在线观看| 国产一区二区三区在线观看免费| 国产精品久久一级| 影音先锋亚洲电影| 亚洲午夜av电影| 蜜桃av一区| 亚洲欧美日韩国产成人| 欧美日本在线| 日韩午夜精品视频| 欧美xx69| 欧美一区二区大片| 亚洲视频一起| 欧美大片第1页| 国产精品永久免费观看| 亚洲国产二区| 欧美激情亚洲| 亚洲精品男同| 午夜精品久久久久久久久久久久久| 免费观看亚洲视频大全| 欧美一区二区观看视频| 香蕉av777xxx色综合一区| 欧美一区二区三区在线观看| 99人久久精品视频最新地址| 老鸭窝亚洲一区二区三区| 国产亚洲精品bt天堂精选| 亚洲男人的天堂在线观看| 亚洲精选一区| 国产日韩高清一区二区三区在线| 亚洲一区在线视频| 亚洲在线成人| 一区二区三区视频观看| 99国产精品99久久久久久| 欧美激情视频免费观看| 一区二区三区色| 亚洲色诱最新| 国产在线观看一区| 免费亚洲电影在线| 国产精品进线69影院| 久久精品日韩欧美| 欧美好骚综合网| 午夜国产欧美理论在线播放| 久久精品国产免费| 久久激情五月激情| 国产一区二区三区视频在线观看| 欧美一区二区三区成人| 免费在线播放第一区高清av| 一区二区不卡在线视频 午夜欧美不卡在| 欧美激情一区在线| 亚洲第一精品在线| 亚洲午夜在线| 中国成人黄色视屏| 亚洲天堂视频在线观看| 欧美在线关看| 欧美日韩日本视频| 久久亚洲综合| 亚洲成色777777在线观看影院 | 国产美女精品人人做人人爽| 91久久精品一区二区别| 激情一区二区三区| 亚洲欧美综合v| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产无遮挡一区二区三区毛片日本| 亚洲国产成人精品视频| 日韩视频在线观看一区二区| 鲁鲁狠狠狠7777一区二区| 亚洲国产一区二区a毛片| 在线视频欧美日韩精品| 国产精品亚洲不卡a| 免费亚洲电影| 午夜精品久久久久久久99水蜜桃| 久久久久久夜精品精品免费| 亚洲国产精品电影在线观看| 欧美视频在线观看| 久久久久久久久蜜桃| 日韩午夜一区| 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲日本电影| 国内精品视频在线播放| 亚洲看片网站| 欧美激情在线狂野欧美精品| 亚洲精品乱码久久久久久蜜桃91 | 国产在线观看一区| 欧美区二区三区| 理论片一区二区在线| 欧美一区二区三区视频在线| 亚洲美女毛片| 亚洲国产欧美另类丝袜| 另类综合日韩欧美亚洲| 欧美亚洲一区二区三区| 一本一本久久a久久精品牛牛影视| 国际精品欧美精品| 国产综合色一区二区三区 | 久久精品国产2020观看福利| 亚洲少妇最新在线视频| 99re6这里只有精品| 亚洲国产一区二区精品专区| 欧美高清视频在线观看| 亚洲高清免费在线| 亚洲人成网站影音先锋播放| 亚洲日本va午夜在线影院| 亚洲日本一区二区三区| 亚洲国产精品一区二区第一页| 欧美高清日韩| 亚洲一区欧美激情| 久久久久久久网| 欧美日韩一区二区三区在线看| 国产精品高潮呻吟久久av黑人| 国产精品久久久久久久久| 在线日本成人| 亚洲一区在线免费观看| 国产精品性做久久久久久| 国产精品影视天天线| 在线免费观看日本一区| 亚洲精品乱码久久久久久久久| 亚洲在线观看视频| 亚洲国产精品美女| 欧美在线视频一区| 欧美香蕉大胸在线视频观看| 国产亚洲欧洲| 亚洲免费在线| 亚洲六月丁香色婷婷综合久久| 欧美亚洲三级| 国产精品久久久久99| 一区二区精品国产| 欧美高清视频www夜色资源网| 中文网丁香综合网| 欧美黄色aa电影| 亚洲精品中文字幕在线观看| 久久婷婷成人综合色| 亚洲综合99| 国产精品五区| 欧美一区二区视频在线观看2020| 亚洲美女一区| 欧美午夜精品久久久久免费视| 日韩午夜电影| 99国内精品久久| 欧美日韩国产在线播放| 亚洲狼人综合| 亚洲韩国青草视频| 欧美日韩精品免费| 亚洲欧美日本国产专区一区| 制服丝袜亚洲播放| 国产区欧美区日韩区| 欧美一级久久久| 久久五月婷婷丁香社区| 亚洲区一区二| 亚洲欧美日韩国产一区| 伊人久久婷婷| 亚洲欧洲综合| 国产欧美高清| 亚洲高清成人| 国内精品久久久久久久影视蜜臀| 久久在线观看视频| 欧美视频精品在线| 美女91精品| 亚洲精品视频在线观看免费| 国产精品一区一区| 亚洲日韩第九十九页| 黑人极品videos精品欧美裸| 亚洲人体1000| 亚洲国产成人porn| 久久国产精品色婷婷| 午夜欧美不卡精品aaaaa| 免费在线一区二区| 欧美日韩免费| 午夜精品久久久久久久99水蜜桃| 久久久之久亚州精品露出| 性欧美暴力猛交另类hd| 欧美三级日本三级少妇99| 欧美激情精品久久久久久| 国内伊人久久久久久网站视频| 亚洲三级影院| 亚洲青涩在线| 激情偷拍久久| 久久久久久久高潮| 亚洲第一综合天堂另类专| 尤物九九久久国产精品的特点| 亚洲欧美日产图| 久久精品在线视频| 亚洲激情图片小说视频|