码迷,mamicode.com
首页 > 其他好文 > 详细

正整数划分的还有一种解法

时间:2017-07-09 10:59:49      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:正整数   ring   tmp   tostring   push   sort   size   i++   join   

Step 1: 
n ==1 : return 1 
n == 2 : return  [1,1],[2]


Step 2:
for n > 2
a.arr.push(n)
b.arr.push([n-1,1])


c.1 get result of recursion(n-2)
c.2 combine n==2 & result => ret
c.3 remove duplicate record in ret


code :


var splitN = function f(n){
if(n == 1) return new Array("1");
else if(n == 2)return new Array("1,1","2");
else{
var tmp = new Array();
tmp.push(n);
tmp.push((n-1) + ",1");


var arr2 = new Array("1,1","2");
var r = f(n-2);


for(var i = 0;i < r.length ; i++){
tmp.push(arr2[0]+"," + r[i]);
tmp.push(arr2[1]+"," + r[i]);
}


//sort each
for(var i = 0;i < tmp.length; i++)tmp [i] = tmp[i].toString().split(‘,‘).sort().join(‘,‘);


//remove duplicate
var tmp2 = new Array();
for(var i = 0;i < tmp.length; i++){if(tmp2.indexOf(tmp[i]) < 0) tmp2.push(tmp[i]);}


return tmp2;
}


}


var ret = splitN(6);
console.log(ret);


正整数划分的还有一种解法

标签:正整数   ring   tmp   tostring   push   sort   size   i++   join   

原文地址:http://www.cnblogs.com/yutingliuyl/p/7140521.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!