js 算法 var arr = [1,2,3,4] 求组合的算法

vararr=[1,2,3,4];求算法算出它的组合要不重复的正序组合这个算出的结果应为1,2,31,2,41,3,42,3,4补充一下这是从4个里选3个进行组合数组ar... var arr = [1,2,3,4]; 求算法算出它的组合 要不重复的正序组合 这个算出的结果应为 1,2,3 1,2,4 1,3,4 2,3,4
补充一下 这是从4个里选3个进行组合 数组arr里不固定几个数 几个一组也是不固定的
展开
 我来答
realbogey
推荐于2016-01-19 · 超过42用户采纳过TA的回答
知道小有建树答主
回答量:84
采纳率:0%
帮助的人:85.6万
展开全部
var arr=[1,2,3,4];

function test()
{
var result="";
for(var i=0;i<arr.length;i++)
{
for(var n=i+1;n<i+3;n++)
{
for(var j=n+1;j<arr.length;j++)
{
result+=arr[i]+","+arr[n]+","+arr[j]+"\r\n";
}
}
}
return result;
}

alert(test());
追问
谢谢回答 刚才忘了说了 这只是一种情况   我这个arr数组不一定是4个的 要求的组合也不一定是3个一组    有可能是var arr=[1,2,3,4,5,6];  5个一组或是4个一组 组合
追答
....那改成这样,满意的话给个采纳。
/**
*@param arr 输入数组
*@param len 你所要求的输出长度(几个一组)
*/
function test(arr,len)
{
var result="";
for(var i=0;i<arr.length-(len-1);i++)
{
var temp=arr[i];

for(var start=i;start<arr.length-(len-1);start++)
{

for(var n=1;n<len-1;n++)
{
temp+=","+arr[start+n];
}

for(var k=start+n;k<arr.length;k++)
{
result+=temp+","+arr[k]+"\r\n";
}
temp=arr[i];
}
}
return result;
}
alert(test([1,2,3,4],3));

alert(test[1,2,3,4],4));
alert(test[1,2,3,4,5],4));
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式