• <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>
            算法學(xué)社
            記錄難忘的征途
            posts - 141,comments - 220,trackbacks - 0
            在這里做一個(gè)小小的說(shuō)明: 之前在QQ空間發(fā)了一篇立志貼, 但是很快補(bǔ)考就來(lái)了, 所以從昨天開(kāi)始算, 一天一道regional題, 三天一套多校...

            250pt

               算法分析:

                  二分枚舉結(jié)果是最好寫(xiě)的, 但是不是最優(yōu)的. 但是我偏偏沒(méi)有選擇最好些的.

            #include<iostream>
            #include<vector>
            #include<cstring>
            using namespace std;
            typedef long long ll;
            ll stk[55];int vis[55];
            bool flag;
            ll work(vector<int> num){
                int tp = 0;
                memset(vis,0,sizeof(vis));
                for(int i = 0; i < num.size(); i++) {
                    if(num[i] == 0) {
                        if(tp <= 1) continue;
                        else {
                            tp --;
                            if(stk[tp ] == -1 || stk[tp-1] == -1){
                                vis[tp - 1] = 1;
                                vis[tp] = 0;
                            }
                            else if(vis[tp] == 1 || vis[tp - 1] == 1) {
                                    vis[tp-1] = 1;
                                    vis[tp] = 0;
                            }
                            stk[tp-1] += stk[tp];
                        }
                    }
                    else {
                        stk[tp++] = num[i];
                    }
                }
                flag = vis[tp-1] || (stk[tp-1] == -1);
                if(flag) stk[tp-1]++;
                return stk[tp-1];
            }
            class 
            Suminator{
                public : int findMissing(vector <int> p, int R){
                    int n = p.size(),s;
                    for(int i = 0; i<n; i++){
                        if(p[i] == -1) s = i;
                    }
                    p[s] = 0;
                    ll t = work(p);
                    if(t == R) return 0;
                    p[s] = -1;
                    t = work(p);
                    if(!flag) {
                        if(t == R) return 1;
                        else return -1;
                    }
                    else {
                        ll x = R - t;
                        if(x < 1) return - 1;
                        else return x;
                    }
                }
            };

            500pt

               算法分析:

                  一共就兩個(gè)凸聯(lián)通塊,每個(gè)凸聯(lián)通塊一定是逐增不(下降,上升)的.
                  于是乎可以DP, DP[i][j][a][b]表示第i層,前j行都選取字母a的行數(shù)不上升/下降的總情況.
            #include<iostream>
            #include<cstdio>
            #include<vector>
            #include<string>
            using namespace std;
            typedef long long ll;
            ll dp[55][55][2][2];
            const int mod = (int)1e9+7;
            class TwoConvexShapes{
                publicint countWays(vector <string> num){
                    int n = num.size(), m = num[0].size();
                    for(int p = 0; p<2; p++){
                        for(int oo = 0; oo <2; oo++) {
                            char x = oo ? 'B' : 'W';
                            char y = oo ? 'W' : 'B';
                            for(int i = 0; i < n; i++){
                                for(int r = 0; r <= m; r++){
                                    bool flag = 1;
                                    for(int j = 0; j < m; j++)
                                        if(j < r && num[i][j] == x || j >= r && num[i][j] == y )
                                            flag = 0;
                                //    if(!flag) cout<<i<<" "<<r<<endl;
                                    if(!flag) continue;
                                    for(int j = 0; j <= m; j++){
                                        if(i==0) dp[i][r][oo][p] = 1;
                                        else if(p && j >= r || !p && j <= r)
                                            dp[i][r][oo][p] += dp[i-1][j][oo][p];
                                    }
                                    dp[i][r][oo][p] %= mod;
                                }}}}
                    //cout<< dp[n-1][0][0][0] <<" "<<dp[n-1][1][0][0]<<" "<<dp[n-1][2][0][0]<<endl;
                    ll ans = 0;
                    for(int i = 0; i <= m; i++)
                        for(int a = 0; a< 2; a++)
                            for(int b = 0; b < 2; b++)
                                ans += dp[n-1][i][a][b];
                    ans %= mod;
                    int sum = 0,w = 0, b = 0;
                    for(int i = 0; i < n; i++)
                        for(int j = 0; j < m; j++)
                            if(num[i][j] == 'W') w = 1;
                            else if(num[i][j] == 'B') b = 1;
                    sum = (!w + !b) * 3;
                    for(int u = 1; u < n; u++)
                        for(int oo = 0; oo < 2; oo++) {
                            bool flag = 1;
                            char x = oo ? 'B' : 'W';
                            char y = oo ? 'W' : 'B';
                            for(int i = 0; i < n; i++)
                                for(int j = 0; j< m; j++)
                                    if(i < u && num[i][j] == x || i >= u && num[i][j] == y)
                                        flag = 0;
                            sum += flag;
                        }
                    for(int r = 1; r < m; r++)
                        for(int oo = 0; oo < 2; oo++) {
                            bool flag = 1;
                            char x = oo ? 'B' : 'W';
                            char y = oo ? 'W' : 'B';
                            for(int i = 0; i < n; i++)
                                for(int j =0; j < m; j++)
                                    if(j < r && num[i][j] == x || j >= r && num[i][j] == y)
                                        flag = 0;
                            sum += flag;
                        }
                //    cout<< ans << " "<< sum<<endl;
                    return (ans - sum + mod) % mod;
                }
            };
            posted on 2012-08-23 16:53 西月弦 閱讀(332) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 解題報(bào)告
            国产三级久久久精品麻豆三级| 热久久视久久精品18| 久久精品国产AV一区二区三区| 色婷婷综合久久久久中文一区二区| 亚洲国产精品久久电影欧美| WWW婷婷AV久久久影片| 久久精品国产一区| 国产91久久综合| 亚洲日本久久久午夜精品| 亚洲精品午夜国产va久久| 色欲久久久天天天综合网精品| 国产成人精品免费久久久久| 久久免费视频6| 久久国产精品无码网站| 狠狠色婷婷综合天天久久丁香| 999久久久免费精品国产| 狠狠综合久久综合中文88| 亚洲国产精品无码久久九九| 久久影院综合精品| 久久av高潮av无码av喷吹| 久久超碰97人人做人人爱| 久久99国产一区二区三区| 久久久久亚洲av无码专区喷水 | 99久久人妻无码精品系列蜜桃 | 久久精品国产2020| 久久香蕉国产线看观看99| 99久久做夜夜爱天天做精品| AV无码久久久久不卡网站下载| 久久乐国产精品亚洲综合| 亚洲av日韩精品久久久久久a| 欧美精品福利视频一区二区三区久久久精品 | 久久夜色精品国产噜噜亚洲a| 国产亚洲美女精品久久久| 欧美一区二区精品久久| 99精品久久精品一区二区| 精品久久久久久国产潘金莲| 人人狠狠综合久久亚洲婷婷| 色综合久久综精品| 久久黄色视频| 久久se这里只有精品| 91秦先生久久久久久久|