博客
关于我
7-14 整数分解为若干项之和 (15分)(附详细讲解(不用递归的高效算法))
阅读量:804 次
发布时间:2019-03-25

本文共 2058 字,大约阅读时间需要 6 分钟。

针对正整数N分解为多个正整数之和的问题,我们需要列举所有可能的分解方法,并按照递增顺序输出。这种分解方法可以采用递归的策略,每次从分解结果中找到一个可以合并的最右边部分,从而逐步简化问题。

针对输入的N=7,分解的思路是:

  • 首先生成一个全由1组成的数组,长度等于N本身;
  • 然后通过不断地合并相邻的部分,直到数组长度再减少为止;
  • 每次合并可以有两种选择:靠近右边的数字是否可以合并,或者需要进行递归调整以保持递增顺序。
  • 通过这种方式,我们可以得到所有可能的分解式子。

    改进后的算法直接在代码中处理分解过程,而不是通过递归调用,从而提高运行效率。这种方法尤其适用于较大的N值(如60及以上),性能提升显著。

    改进后的代码如下:

    #include 
    int main(void) { int n, i, len, origin, count, temp; int leap = 1; int a[30] = {0}; scanf("%d", &n); len = n; origin = len; for (i = 0; i < len; ++i) a[i] = 1; for(;;) { up: if (leap != 1) { printf("; "); printf("%d = ", n); for (i = 0; i < len; ++i) if(i == 0) printf("%d", a[i]); else printf("+%d", a[i]); ++count; if (count == 4) { printf("\n"); count = 0; } } if (a[0] == n) break; if (a[len-1] - a[len-2] <= 4) { ++a[len-2]; if (a[0] == n) goto up; --a[len-1]; temp = a[len-1]; for (i = len-1; i < origin; ++i) { if ((temp - a[len-2]) < a[len-2] && (temp - a[len-2]) != 0) { a[i] = a[len-2]; len = i + 1; temp -= a[len-2]; goto up; } } if (temp == 0) { if (a[len-1] == a[len-2] || (a[len-1] - a[len-2] == 1)) { a[len-2] += a[len-1]; --len; goto up; } if (a[0] > n) goto end; } else { a[len-1] -= 1; a[len-2] += 1; if (a[0] > n) goto end; } } else { a[len-1] -= 1; a[len-2] += 1; if (a[0] > n) goto end; } } end: return 0;}

    这种改进的算法直接在循环体内处理分解过程,减少了函数调用开销,显著提升了性能,特别是对于较大的N(如60及以上),效率提升明显。

    转载地址:http://rtnyk.baihongyu.com/

    你可能感兴趣的文章
    OSG学习:场景图形管理(二)——单窗口多相机渲染
    查看>>
    OSG学习:场景图形管理(四)——多视图多窗口渲染
    查看>>
    OSG学习:新建C++/CLI工程并读取模型(C++/CLI)——根据OSG官方示例代码初步理解其方法
    查看>>
    Sql 随机更新一条数据返回更新数据的ID编号
    查看>>
    OSG学习:空间变换节点和开关节点示例
    查看>>
    OSG学习:纹理映射(一)——多重纹理映射
    查看>>
    OSG学习:纹理映射(七)——聚光灯
    查看>>
    OSG学习:纹理映射(三)——立方图纹理映射
    查看>>
    OSG学习:纹理映射(二)——一维/二维/简单立方图纹理映射
    查看>>
    OSG学习:纹理映射(五)——计算纹理坐标
    查看>>
    OSG学习:纹理映射(六)——灯光
    查看>>
    OSG学习:纹理映射(四)——三维纹理映射
    查看>>
    OSI七层模型的TCP/IP模型都有哪几层和他们的对应关系?
    查看>>
    OSM数据如何下载使用(地图数据篇.11)
    查看>>
    OSPF 四种设备角色:IR、ABR、BR、ASBR
    查看>>
    SQL Server 存储过程分页。
    查看>>
    OSPF不能发现其他区域路由时,该怎么办?
    查看>>
    OSPF两个版本:OSPFv3与OSPFv2到底有啥区别?
    查看>>
    SQL Server 存储过程
    查看>>
    OSPF在大型网络中的应用:高效路由与可扩展性
    查看>>