• <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>
            付翔的專欄
            在鄙視中成長 記錄成長的點滴
            posts - 106,  comments - 32,  trackbacks - 0

            大概的題意是: 給定一個序列 1 。。N ,假設(shè)全集為U那么存在多少種情況 : 兩個子集A B其中A∩B=∅ ,A∪B=U ,A元素的和== B元素的和。

            開始寫了個遞歸,枚舉,提交超時:void work(int deep,int start)

            {
                if(deep >= n)    return;
                if(ans > (sum -ans)) return ;
                if(ans == sum-ans)
                {
                    gcount ++;
                    /*FOR_1(i,1,n){
                        if(used[i] == 1)
                        fout<<i<< " ";
             
                    }
                    fout<<endl;
            */
                    return ;
                }
             
                FOR_1(i,start + 1,n){
                    if(used[i] == 0){
                        used[i] = 1;
                        ans += i;
                        work(deep + 1,i);
                        used[i] = 0;
                        ans -= i;
                    }
                }
             
            }

            之后改用另外一種思路,f(n,ans) = f(n-1,ans-n) + f(n-1,ans) ,這個有點分治的思路,把問題的規(guī)模逐漸縮小,從而得到解。中間加了個優(yōu)化,用一個二維數(shù)組存下中間計算的結(jié)果,這樣就不會超時。

            /*
            ID:fuxiang2
            PROG: subset
            LANG: C++
            */
            #include <iostream>
            #include <fstream>
            #include <stack>
            #include <string>
            #include <vector>
            #include <queue>
            #include <map>
            #include <list>
            #include <algorithm>
            #include <set>
            #include <cmath>
            #include <cstring>
            #include <cstdlib>
             
            #define REP(i, n) for (int i=0;i<int(n);++i)
            #define FOR(i, a, b) for (int i=int(a);i<int(b);++i)
            #define DWN(i, b, a) for (int i=int(b-1);i>=int(a);--i)
            #define REP_1(i, n) for (int i=1;i<=int(n);++i)
            #define FOR_1(i, a, b) for (int i=int(a);i<=int(b);++i)
            #define DWN_1(i, b, a) for (int i=int(b);i>=int(a);--i)
            #define EACH(it, A) for (typeof(A.begin()) it=A.begin(); it != A.end(); ++it)
             
            using namespace std;
            ofstream fout ("subset.out");
            ifstream fin ("subset.in");
             
            const int N = 40;
            int used[N];
            int n ;
            int sum;
            int ans ;
            int gcount ;
            int data[40][800];
            void work(int deep,int start)
            {
                if(deep >= n)    return;
                if(ans > (sum -ans)) return ;
                if(ans == sum-ans)
                {
                    gcount ++;
                    /*FOR_1(i,1,n){
                        if(used[i] == 1)
                        fout<<i<< " ";
             
                    }
                    fout<<endl;
            */
                    return ;
                }
             
                FOR_1(i,start + 1,n){
                    if(used[i] == 0){
                        used[i] = 1;
                        ans += i;
                        work(deep + 1,i);
                        used[i] = 0;
                        ans -= i;
                    }
                }
             
            }
             
            int solve(int n ,int ans)
            {
                int msum = (n+1)*n/2;
                if(ans <= 0) return 0;
                if(msum < ans) return 0 ;
                else if(msum == ans ) return 1 ;
             
                if(data[n][ans] )
                    return data[n][ans] ;
             
                data[n-1][ans-n] = solve(n-1,ans-n);
                data[n-1][ans] = solve(n-1,ans);
             
                return data[n-1][ans-n] + data[n-1][ans];
            }
            int main()
            {
                fin>>n;
                sum = (1+n)*n/2;
                ans = 0;
                if(sum%2 ==1){
                    fout<<"0"<<endl;
                }
                else {
                    //work(0,0);
                    
            //fout<<gcount/2 <<endl;
                    int re = solve(n,sum/2);
                    fout<<re<<endl;
                }
             
                //int re = solve(n,sum/2);
                
            //fout<<re<<endl;
                return 0;
             
            }
            原始博客地址:http://www.fuxiang90.com/2012/07/usaco2-2-subset-sums/
            posted on 2012-07-26 23:16 付翔 閱讀(277) 評論(0)  編輯 收藏 引用 所屬分類: ACM 數(shù)據(jù)結(jié)構(gòu)

            <2011年3月>
            272812345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            CSDN - 我的blog地址

            博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            伊人久久大香线蕉综合影院首页| 国产精品免费久久久久电影网| 亚洲精品午夜国产VA久久成人| 精品国产青草久久久久福利| 久久天天躁狠狠躁夜夜96流白浆| 久久精品国产69国产精品亚洲 | 日韩精品无码久久一区二区三| 亚洲国产精品嫩草影院久久| 久久久女人与动物群交毛片| 国产精品成人久久久久三级午夜电影| 国内精品久久久久影院亚洲| 久久久亚洲欧洲日产国码二区| 精品无码人妻久久久久久| 久久99九九国产免费看小说| 91亚洲国产成人久久精品网址| 久久人妻无码中文字幕| 国产精品成人久久久久久久| 久久精品aⅴ无码中文字字幕重口| 国产成人精品久久| 久久ZYZ资源站无码中文动漫| 亚洲欧美成人久久综合中文网| 国产精品久久网| 青草国产精品久久久久久| 久久精品国产99久久丝袜| 国产精品久久99| 欧美亚洲色综久久精品国产| 免费一级欧美大片久久网 | 久久精品国产亚洲网站| 久久久久久亚洲精品影院| 久久99国产一区二区三区| 久久伊人精品青青草原高清| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 久久精品国产亚洲网站| 久久久久久亚洲AV无码专区| 亚洲国产另类久久久精品小说| 亚洲精品国精品久久99热| 久久久久久久国产免费看| 久久久久97国产精华液好用吗| 精品久久久久中文字幕一区| www亚洲欲色成人久久精品| 国产精品欧美久久久久无广告 |