子集的递归和

时间:2013-05-02 23:10:52

标签: c++ recursion subset-sum

我已经阅读了其他一些讨论,但无法弄清楚如何修复我的程序。当它递归时,我的索引计数器最终变得太大而且有希望不起作用,因为它超出界限(或者至少我认为这是正确的)。我怎样才能解决这个问题,索引永远不会太大?

vector<uint> w;                // vector of weights
vector<bool> include;
uint W;                        // the desired weight
uint index = 0;
uint weight = 0;               // the current weight of subsets
uint total = 0;                // superset total

void sum_of_subsets( uint index,
                     uint weight,
                     uint total,
                     vector<bool> &include,
                     vector<uint> &w,
                     uint W )
{
    if( promising(index, weight, W, w, total) )
    {
        if( weight == W )
        {
            for( uint k = 0; k <= include.size(); k++ )
            {
                if(include.at(k))
                    cout << w.at(k) << " ";
            }
        }
        else
        {
            include.at(index + 1) = 1;
            sum_of_subsets( index + 1, 
                            weight + w.at(index + 1 ), 
                            total - w.at(index + 1),
                            include, w, W ) ;
            include.at(index + 1) = 0;
            sum_of_subsets( index + 1, 
                            weight, 
                            total - w.at(index + 1),
                            include, w, W );
        }
    }
}

bool promising ( uint index, 
                 uint weight, 
                 uint W, 
                 vector<uint> w,
                 uint total )
{
    return ( weight + total >= W )
            && ((weight == W) || (weight + w.at(index+1) <= W));
}

0 个答案:

没有答案