博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
整数划分问题
阅读量:5819 次
发布时间:2019-06-18

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

1 /* 2 Subject:计算机算法设计与分析 3 Title:例2-5 整数划分问题:输出一个整数的所有划分并统计总划分数 4 Coder:Hao 5 Class:计科0906 6 Num:0304090614 7 Date:Sept 20th,2011 8 */ 9 10 #include 
11 using namespace std;12 13 //用于打印(输出)的函数 14 //result为存储某划分结果的数组,length为此划分所占长度-1(从0开始) 15 void display(int *result, int length)16 {17 for (int i = 0; i
=1并且m=1时,q(n,m,result,length)=q(n-1,m,result,length) 31 if (n >= 0 && m == 1) {32 //直至n=0并且m=1时,输出 33 if (n == 0) {34 display(result, length);35 }36 else {37 result[length] = 1;38 q(n - 1, m, result, length + 1);39 }40 return 1;41 }42 43 44 // 当 n=1并且m>1 时,分解已经完成,进行输出 45 else if (n == 1 && m>1)46 {47 result[length] = n;48 display(result, length + 1);49 return 1;50 }51 52 //当n
m>1时,67 //q(n,m,result,length)=q(n-m,m,result,length+1)+q(n,m-1,result,length) 68 else69 {70 result[length] = m;71 return q(n - m, m, result, length + 1) + q(n, m - 1, result, length);72 }73 }74 void main()75 {76 int n; 77 char c;78 //定义待划分整数 79 int result[100] = { 0 }, length = 0; //初始化80 81 cout << "please input the integer:";82 cin >> n;83 cout << "整数" << n << "的划分个数为" << q(n, n, result, length) << endl;84 85 cin >> c;86 }

 

转载于:https://www.cnblogs.com/jangsay/p/5902955.html

你可能感兴趣的文章
argparse - 命令行选项与参数解析(转)
查看>>
一维数组
查看>>
Linux学习笔记之三
查看>>
CentOS 6.6 FTP install
查看>>
图解Ajax工作原理
查看>>
oracle导入导出小记
查看>>
聊一聊log4j2配置文件log4j2.xml
查看>>
NeHe OpenGL教程 第七课:光照和键盘
查看>>
修改上一篇文章的node.js代码,支持默认页及支持中文
查看>>
Php实现版本比较接口
查看>>
删除设备和驱动器中软件图标
查看>>
第四章 TCP粘包/拆包问题的解决之道---4.1---
查看>>
html语言
查看>>
从源码看集合ArrayList
查看>>
spring-boot支持websocket
查看>>
菜鸟笔记(一) - Java常见的乱码问题
查看>>
我理想中的前端工作流
查看>>
记一次Git异常操作:将多个repository合并到同一repository的同一分支
查看>>
CodeIgniter 3.0 新手捣鼓源码(一) base_url()
查看>>
Chrome 广告屏蔽功能不影响浏览器性能
查看>>