力扣面试题16.11 跳水板
题目:
看到这一题,我脑海中想到的就是利用数学知识来解决这一问题。
跳水板的长度=(短板的长度×(木板数-i))+长板的长度×(i)(其中i是指长板的数量)
当然,这只是一般的情况,还有木板数为0和短板、长板长度一样这两种情况需要讨论,综合起来,主要有三种情况:
①当木板数k=0时,此时代表无跳水板,返回空;
②当短长板长度一样时,此时只需考虑需要的木板数k,则可能的长度就只有一种情况:木板数k×模板长度;
③当木板数不为0且短木板长度一样时,使用公式{跳水板的长度=(短板的长度*(木板数-i))+长板的长度*(i)(其中i是指长板的数量)}来求解;
我用的是JavaScript语言来写的,看起来还不错!
下面开始上我写的代码:
var divingBoard = function(shorter, longer, k) {
var s=new Array();//申请数组存可能的长度
if(k===0)//当木板数k为0时返回空值
{
return s;
}
else if(shorter===longer)//木板长度一样时
{
s[0]=shorter*k;
return s;
}
else{//木板数k不为0且木板长度不一样时
var m=longer*k;
var i=0;
while(i<=k)
{
s.push((shorter*(k-i))+longer*(i));
i++;
}
return s;
}
};
每日一刷,博客记录,总结经验!欢迎留言一起讨论。