• <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)告
            欧美精品一区二区久久| 欧美一区二区三区久久综合| 久久综合九色综合久99| 国产免费久久精品99久久| 久久精品一区二区影院| av色综合久久天堂av色综合在| 久久婷婷激情综合色综合俺也去| 99久久国产综合精品网成人影院 | 日韩精品久久久久久免费| av无码久久久久不卡免费网站 | 久久久久这里只有精品| 精品久久久噜噜噜久久久 | 精品国产乱码久久久久久呢| 91久久成人免费| 久久这里只有精品18| 久久夜色撩人精品国产小说| 99久久精品国产高清一区二区| 亚洲人成电影网站久久| 国产香蕉97碰碰久久人人| 久久久久国产精品熟女影院 | 精品久久久久香蕉网| 国内精品综合久久久40p| 久久免费99精品国产自在现线| 国产成人久久精品区一区二区| 国产成人精品三上悠亚久久| 日本精品久久久久久久久免费| 成人免费网站久久久| 人妻少妇久久中文字幕| 色欲久久久天天天综合网| 国产成人无码精品久久久性色| 超级碰碰碰碰97久久久久| 四虎亚洲国产成人久久精品| 久久涩综合| 噜噜噜色噜噜噜久久| 久久精品综合网| 伊人久久综合成人网| 亚洲AV无码1区2区久久 | 久久精品国产黑森林| 久久久久综合国产欧美一区二区| 青青草国产精品久久| 精品久久人人做人人爽综合|