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

            C小加

            厚德 博學(xué) 求真 至善 The bright moon and breeze
            posts - 145, comments - 195, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            NYOJ 110 劍客決斗(簡單DP)

            Posted on 2012-03-22 10:30 C小加 閱讀(580) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告

            細(xì)節(jié)沒有處理好,導(dǎo)致超時了好多次。

            對于ij中間的k,如果ij能遇見ki能打敗k或者j能打敗k,則i就能遇見j,用f[i][j]表示ij是否能遇見。如果i最終能遇見自己,那么i就有取得勝利的可能。

            沒有開大數(shù)組的必要,直接取余就可以。得看明白那些是最優(yōu)子結(jié)構(gòu),否則你沒辦法DP

            時間復(fù)雜度為O(n^3)

            //NYOj110
            //Time:732 Memory:720
            #include<iostream>
            #include<cstdio>
            #include<cstring>
            //#include<>
            using namespace std;

            bool a[503][503];
            bool f[503][503];


            int main()
            {
                int t;
                scanf("%d",&t);
                while(t--)
                {
                    int n;
                    scanf("%d",&n);
                    for(int i=0;i<n;i++)
                    {
                        for(int j=0;j<n;j++)
                        {
                            scanf("%d",&a[i][j]);
                        }
                    }
                    memset(f,0,sizeof(f));
                    for(int i=0;i<n;i++)
                    {
                        f[i][(i+1)%n]=1;
                    }
                    for(int i=2;i<=n;i++)
                    {
                        for(int j=0;j<n;j++)
                        {
                            int e=(j+i)%n;
                            if(f[j][e]) continue;
                            for(int k=(j+1)%n;k!=e;k++,k%=n)
                            {
                                if(f[j][k]&&f[k][e]&&(a[j][k]||a[e][k]))
                                {
                                    f[j][e]=1;
                                    break;
                                }
                            }
                        }
                    }
                    int ans=0;
                    for(int i=0;i<n;i++)
                    {
                        if(f[i][i]) ans++;
                    }
                    printf("%d\n",ans);
                }
                return 0;
            }

            天堂无码久久综合东京热| 亚洲人成伊人成综合网久久久| 狠狠色噜噜狠狠狠狠狠色综合久久| 99久久精品毛片免费播放| 欧美精品丝袜久久久中文字幕 | 久久精品成人免费网站| 国产激情久久久久影院老熟女免费| 香蕉99久久国产综合精品宅男自| 亚洲αv久久久噜噜噜噜噜| 久久黄视频| 国产成人久久激情91| 久久国产欧美日韩精品免费| 91精品国产91热久久久久福利| 色婷婷综合久久久久中文一区二区| 麻豆精品久久精品色综合| 色综合久久久久无码专区| 亚洲国产成人久久综合野外| 97久久精品人人澡人人爽| 亚洲中文字幕无码久久精品1| 久久九九久精品国产| 久久精品国产99国产精品澳门| 99久久国产综合精品女同图片| 欧美久久综合九色综合| 一本色道久久88加勒比—综合| 久久天堂AV综合合色蜜桃网| 国产精品久久久久免费a∨| 色偷偷88欧美精品久久久 | 欧美午夜精品久久久久免费视 | 久久亚洲综合色一区二区三区| 久久久久久久人妻无码中文字幕爆| 中文字幕无码久久久| 久久久国产视频| av色综合久久天堂av色综合在| 久久国产精品无| 2020国产成人久久精品| 精品国产乱码久久久久久呢 | 香蕉久久夜色精品国产尤物| 久久综合九色综合欧美就去吻| 人妻无码精品久久亚瑟影视| 香蕉久久永久视频| 国产成人精品综合久久久|