最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript趣题:出Bug的等差数列

来源:懂视网 责编:小采 时间:2020-11-27 20:25:15
文档

JavaScript趣题:出Bug的等差数列

JavaScript趣题:出Bug的等差数列:一个程序在创建等差数列时出了Bug,等差数列中某一项被丢失了,其他项好完好,请找出这个丢失项。比如:1,3,5,9,11,这里的丢失项很明显是7。你得写一个函数,findMissing (list) ,它接收一个等差数列列表,列表至少有3个元素,丢失项不会是第一个或最后一个
推荐度:
导读JavaScript趣题:出Bug的等差数列:一个程序在创建等差数列时出了Bug,等差数列中某一项被丢失了,其他项好完好,请找出这个丢失项。比如:1,3,5,9,11,这里的丢失项很明显是7。你得写一个函数,findMissing (list) ,它接收一个等差数列列表,列表至少有3个元素,丢失项不会是第一个或最后一个

一个程序在创建等差数列时出了Bug,等差数列中某一项被丢失了,其他项好完好,请找出这个丢失项。

比如:1,3,5,9,11,这里的丢失项很明显是7。

你得写一个函数,findMissing (list) ,它接收一个等差数列列表,列表至少有3个元素,丢失项不会是第一个或最后一个。

来个例子:

findMissing ([1,3,5,9,11]); // 7

PS:这是Facebook在interviewstreet上的工程师挑战例题,大家拿张白纸和笔,写写划划应该很快能解出来。

好了,咋们来看看解题思路:

我个人感觉,对付此类问题,也就是说,至少3个元素的题目,它往往暗示了你,三个元素内要“决出胜负”。

对于这个题目,三个元素内要推算出等差数列的公差。

先来看前三个元素的例子:

7,5,1

大家一眼就可以看出,第一个元素和第二个元素相差-2,第二个元素和第三个元素相差-4,那么公差是-2。

所以,对于递减数列这种情况,公差是:

Math.max(list[1]-list[0],list[2]-list[1]);

再看另一个倒过来的例子:

1,5,7

第一个元素和第二个元素相差4,第二个元素和第三个元素相差2,那么公差是2。

对于递增数列的情况,公差就是:

Math.min(list[1]-list[0],list[2]-list[1]);

既然算出来了公差,那剩下的事儿就好办了,从第一个数依次用公差,一一比对列表中的数,遇到不相等的,那就是Miss的项了。

var findMissing = function (list) {
 var diff1$0 = list[1]-list[0];
 var diff2$1 = list[2]-list[1];
 var diff = diff1$0 < 0 ? Math.max(diff1$0,diff2$1) : Math.min(diff1$0,diff2$1);
 for(var i=list[0],j=0;j<=list.length;i+=diff,j++){
 if(i !== list[j]){
 return i;
 }
 }
}

文档

JavaScript趣题:出Bug的等差数列

JavaScript趣题:出Bug的等差数列:一个程序在创建等差数列时出了Bug,等差数列中某一项被丢失了,其他项好完好,请找出这个丢失项。比如:1,3,5,9,11,这里的丢失项很明显是7。你得写一个函数,findMissing (list) ,它接收一个等差数列列表,列表至少有3个元素,丢失项不会是第一个或最后一个
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top