如何将值分配到向量中

时间:2016-02-26 11:44:28

标签: c++ c++11 visual-c++

我需要帮助将值分配到矢量中并打印所有可能的组合,例如 如果用户输入的第一个值将是矢量大小input1size = 15; 然后input2是要在向量内分布的值。 input2 = 25; 第3个输入是向量input3 = 2的第一个常数值;那么这个值减去input2就是我需要在vector

中分配的值

分布矢量后看起来像这样。当我们添加矢量 输出数据需要= = input2 = 25;第一个值是用户输入3;

{{1}}

所以.....并找到所有序列 我怎么能这样做......

1 个答案:

答案 0 :(得分:0)

那样的东西?虽然没有优化它(丑陋的递归)。

#include <iostream>
#include <vector>
#include <deque>
#include <algorithm>

std::vector<std::deque<int>> getcombo(int a, std::deque<int> combo = {})
{
    int sum = std::accumulate(combo.begin(), combo.end(), 0);
    std::vector<std::deque<int>> output;
    std::deque<int> extcombo;
    if(sum == a)
    {
        return std::vector<std::deque<int>> ({combo});
    }
    else
    {
        for(int i=1; i<a+1; ++i)
        {
            if(sum + i <= a)
            {
                extcombo = combo;
                extcombo.push_back(i);
                for(auto c : getcombo(a, extcombo))
                    output.push_back(c);
            }
        }
    }
    return output;
}

std::vector<std::deque<int>> final_combo(size_t size, int sum, int first)
{
    --size;
    auto final = getcombo(sum-first);
    auto new_end = std::remove_if(final.begin(), final.end(),
                                  [size](auto deq) {return deq.size() != size;});
    final.erase(new_end, final.end());

    for(auto&& x : final)
        x.push_front(first);
    return final;
}

int main()
{
    for (auto x : final_combo(5, 11, 4))
    {
        for(auto y : x)
            std::cout << y << ", ";
        std::cout << std::endl;
    }
}