登录  /  注册
首页 > web前端 > js教程 > 正文

JavaScript趣题:出Bug的等差数列

黄舟
发布: 2017-02-13 16:21:01
原创
1312人浏览过

一个程序在创建等差数列时出了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的等差数列 的内容,更多相关内容请关注PHP中文网(www.php.cn)!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号