• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0

            lie[i]==false表示第i列還沒有任何棋子;dui1[i]==false表示向右傾斜的、從上到下的第i條對(duì)角線上還沒有任何棋子;dui2[i]==false表示向左傾斜的、從上到下的第i條對(duì)角線上還沒有任何棋子。
            利用這些記錄優(yōu)化搜索。
            n==13的數(shù)據(jù)我用了403ms。
            以下是我的代碼:

            #include<iostream>
            #include
            <string.h>
            #define maxn 17
            using namespace std;

            long n,cnt,ans[maxn];
            bool lie[maxn],dui1[2*maxn],dui2[2*maxn];

            long f1(long x,long y)
            {
                
            return (x-y+n);
            }
            long f2(long x,long y)
            {
                
            return (x+y-1);
            }

            void dfs(long dep)
            {
                
            if(dep>n)
                {
                    cnt
            ++;
                    
            if(cnt>3return;
                    
            for(long i=1;i<=n;i++)
                    {
                        
            if(i!=1) cout<<" ";
                        cout
            <<ans[i];
                    }
                    cout
            <<endl;
                    
            return;
                }
                
            for(long i=1;i<=n;i++)
                    
            if(!lie[i]&&!dui1[f1(dep,i)]&&!dui2[f2(dep,i)])
                    {
                        lie[i]
            =dui1[f1(dep,i)]=dui2[f2(dep,i)]=true;
                        ans[dep]
            =i;
                        dfs(dep
            +1);
                        lie[i]
            =dui1[f1(dep,i)]=dui2[f2(dep,i)]=false;
                    }
            }

            int main()
            {
                cin
            >>n;
                
                cnt
            =0;
                memset(lie,
            false,sizeof(lie));
                memset(dui1,
            false,sizeof(dui1));
                memset(dui2,
            false,sizeof(dui2));
                dfs(
            1);
                cout
            <<cnt<<endl;
                
            return 0;
            }
            posted on 2010-10-22 21:35 lee1r 閱讀(348) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 題目分類:搜索
            久久er国产精品免费观看2| 内射无码专区久久亚洲| 一极黄色视频久久网站| 99久久夜色精品国产网站| 久久久久女人精品毛片| 伊人久久大香线蕉av一区| 久久综合亚洲色HEZYO社区| 国产精品美女久久福利网站| 无夜精品久久久久久| 怡红院日本一道日本久久| 久久久久国产一级毛片高清版| 久久精品亚洲一区二区三区浴池| 狠狠综合久久AV一区二区三区| 精品国产乱码久久久久久人妻| 波多野结衣久久一区二区| 国内精品久久久久久久久电影网 | 狠狠色综合网站久久久久久久| 久久99热精品| 九九久久精品国产| 亚洲午夜精品久久久久久浪潮| 2020国产成人久久精品| 午夜精品久久久久久中宇| 久久精品国内一区二区三区| 国产精品无码久久久久| 久久久久久午夜精品| 久久久久高潮毛片免费全部播放| 久久97精品久久久久久久不卡| 99久久国产综合精品网成人影院| 久久久久亚洲爆乳少妇无| 亚洲国产另类久久久精品黑人| 精品亚洲综合久久中文字幕| 青草久久久国产线免观| 久久久久亚洲Av无码专| 久久精品成人免费国产片小草| 狠狠色丁香久久婷婷综合蜜芽五月 | 亚洲乱码日产精品a级毛片久久| 伊人久久大香线蕉综合影院首页 | 亚洲午夜福利精品久久| 亚洲欧洲日产国码无码久久99| 国产精品综合久久第一页| 日本欧美久久久久免费播放网 |