| 查看: 521 | 回复: 2 | |||
[求助]
matlab编程,几个正整数的和为定值,且后一个不小于前一个,求所有组合 已有1人参与
|
|
几个正整数的和为定值,且后一个不小于前一个,求所有的组合。例如,x1+x2+x3=10,x1<=x2<=x3,求所有的可能组合,用matlab编写程序。感谢! 发自小木虫Android客户端 |
» 猜你喜欢
有没有人能给点建议
已经有5人回复
假如你的研究生提出不合理要求
已经有12人回复
实验室接单子
已经有7人回复
全日制(定向)博士
已经有5人回复
萌生出自己或许不适合搞科研的想法,现在跑or等等看?
已经有4人回复
Materials Today Chemistry审稿周期
已经有4人回复
参与限项
已经有3人回复
对氯苯硼酸纯化
已经有3人回复
所感
已经有4人回复
要不要辞职读博?
已经有7人回复
wurongjun
专家顾问 (职业作家)
-

专家经验: +831 - 数学EPI: 9
- 应助: 791 (博后)
- 贵宾: 0.308
- 金币: 24609
- 散金: 310
- 红花: 75
- 帖子: 3004
- 在线: 881.2小时
- 虫号: 1368482
- 注册: 2011-08-14
- 性别: GG
- 专业: 计算数学与科学工程计算
- 管辖: 数学

2楼2017-06-26 07:45:25
|
%先做一个代换使得: %x_(1)=y_(1) %x_(2)=y_(1)+y_(2) %x_(3)=y_(1)+y_(2)+y_(3) %... %x_(k)=y_(1)+y_(2)+...+y_(k) %其中y_(1)>=1; y_(i)>=0 (2<=i<=k) %最终有k*y_(1)+(k-1)*y_(2)+...+y_(k)=m %对于维度较小的 不妨直接循环 p=1; for i=1:fix(10/3) for j=0:fix((10-3*i)/(3-1)) for l=0:fix((10-3*i-(3-1)*j)/(3-2)) if 3*i+(3-1)*j+l*(3-2)==10 x{p}=cumsum([i,j,l]); p=p+1; end end end end |

3楼2017-06-26 08:30:58












回复此楼
=[x1 x2 x3];