求正整数的所有分割并输出II

Posted unclerunning

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求正整数的所有分割并输出II相关的知识,希望对你有一定的参考价值。

求正整数的所有分割并输出II

函数Part(N,M)能得到N不大于M的所有分割的集合。

#include<iostream>
#include<vector>
#include<algorithm>
#include<iterator>

using namespace std;

/*
求正整数的所有分割并输出:

case 1: N>M,    Part(N,M)为集合Part(N,M-1)并上M+Part(N-M,M)集合
case 2: N==M,   Part(N,M)为集合Part(N,M-1)并上M
case 3: N<M     Part(N,M)为集合Part(N,N)
case 4: N==1    Part(N,M)为集合1
case 5: M==1    Part(N,M)为集合1,1,1...,1(共N个1)
*/
vector<vector<int>> Part(int N ,int M)

    vector<vector<int>> ret;

    // 1个1
    if (N == 1)
    
        vector<int> cur;
        cur.push_back(1);
        ret.push_back(cur);
        return ret;
    

    // N个1
    if (M == 1)
    
        vector<int> cur;
        for (int i(0); i < N; i++)
        
            cur.push_back(1);
        
        ret.push_back(cur);
        return ret;
    

    if (N < M)
    
        return Part(N,N);
    

    if (N == M)
    
        ret = Part(N, M - 1);
        vector<int> cur;
        cur.push_back(M);
        ret.push_back(cur);
        return ret;
    

    // N>M
    ret = Part(N, M - 1);
    vector<vector<int>> temp = Part(N - M, M);
    for (vector<int> &v : temp)
    
        v.push_back(M);
        ret.push_back(v);
    

    return ret;



int main()

    vector<vector<int>> result;
    int n;
    cout << "请输入想要分割的正整数n:" << endl;
    cin >> n;

    result = Part(n, n);
    cout << "所有分割的结果:" << endl;
    cout << endl;
    for (int i(0); i < result.size(); i++)
        cout << "";
        cout << result[i][0];
        for (int j(1); j < result[i].size(); j++)
            cout << "," << result[i][j];
        cout << "";
        cout << endl;
    
    cout << endl;
    cout << "划分数目:" << result.size() << endl;
    cout << endl;
    system("pause");

    return 0;

以上是关于求正整数的所有分割并输出II的主要内容,如果未能解决你的问题,请参考以下文章

[HNOI2001]求正整数

C语言逆置正整数求教

编程:求正整数内与7无关(数字中不含7,不是7的倍数)的所有数之和

求正整数2和n之间的完全数

华为机试真题 C++ 实现水仙花数II(字符串分割)

剑指 Offer II 104. 排列的数目