zoukankan      html  css  js  c++  java
  • 整数拆分

    将一个整数拆分成不重复的整数之和。

    example:

       6 = 1 + 5 = 1 + 2 + 3
          = 2 + 4

    采用递归方法实现。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    #include <iostream>
       
    #include <vector>
       
    using namespace std;
       
       
    /**
       
        6 = 1 + 5 = 1 + 2 + 3
       
          = 2 + 4
       
    **/
       
       
    void split( int n, int s, vector<int>  ret)
       
    {
       
        // 递归结束条件
       
        if ( n <= 2*s)
       
        {
       
            vector<int>::iterator iter;
       
            ret.push_back(n);
       
            //注意打印的位置:递归结束时
       
            for ( iter = ret.begin(); iter != ret.end(); iter++ )
       
            {
       
                cout << *iter << '\t';
       
            }
       
       
            cout << endl;
       
        }
       
       
        for int i = s; i < (n+1)/2; i++ )    
       
        {
       
            // pop 上一分支的数据
       
            if ( i != s)
       
                ret.pop_back();
       
       
            ret.push_back(i);    
       
            split(n-i, i+1, ret);
       
        }
       
       
    }
        
    int main(int argc, char** argv)
       
    {
       
        vector<int> ret;
       
           
       
        int n = 20;
       
        split(n,1, ret);
       
       
        return 0;
       
    }
  • 相关阅读:
    JavaScript中的this相关
    Git进阶操作_1
    Git基本操作_5
    Git基本操作_4
    Git基本操作_3
    Git基本操作_2
    利用Python发送SMTP邮件
    Python JWT使用
    Python中的Asyncio 异步编程
    Python中的抽象类和接口类
  • 原文地址:https://www.cnblogs.com/simonote/p/3095306.html
Copyright © 2011-2022 走看看