( 译文 ) JavaScript中算法和数据结构

请各位读者添加一下作者的微信公众号,以后有新的文章,将在微信公众号直接推送给各位,非常感谢。


0. 前言


今天一直在整理关于面试的内容,希望能够让我的兄弟姐妹们在未来能够有所借鉴。

在整理的时候,发现有一位歪果友人写的文章非常6,所以趁机翻译一下,分享给大家。

译文的原文如下:

Algorithms and data structures in JavaScript

1.正文


在今天的文章中会是一个非常重要的主题,即:在JavaScript中算法和数据结构。这是编程的一个重要话题。我们不应该有偏见——Javascript很适合这一目的。也许有些事情将在解说语言有点困难,但是别人会简化,例如基本堆栈实现(FIFO)。

1.1 Factorial(阶乘)

在开始一个典型的例子——阶乘和递归。

示例——计算阶乘JavaScript:

function factorial(n) {
    if (n == 0)
        return 1;
    else
        return (n * factorial(n-1));
}
 
alert(factorial(5));

1.2 Leap year(闰年)

下一个算法是检查是否某一年是一个闰年。

// is leap year - JavaScript
function checkLeapYear(year) {
    if ( ((year % 4 == 0) 
          && 
          (year % 100 != 0)) || (year % 400 == 0) ) {
        alert(year + ' is leap');
         
        return true;
    } else {
        alert(year + ' is NOT leap');
         
        return false;
    }
}
 
alert(checkLeapYear(2012));
alert(checkLeapYear(2013));

1.3 Min-Max algorithm(Min-Max算法)

所以确定最低和最高的给定值。

示例——在JavaScript min-max算法的实现:

var tab = new Array(16, 9, 86, 48, 59, 2, 78, 240, 18);
// default
var min = tab[0];
var max = tab[0];
 
for (var i = 0; i < tab.length; i++) {
     
    if (min > tab[i]) {
        min = tab[i];
    }
   
    if (max < tab[i]) {
        max = tab[i];
    }
}
 
alert("Min = " + min + ", Max = " + max);

这是一个简单,但有效实施基于数组中元素之间的比较。

1.4 Random string(随机字符串)

这个算法是一个简单的发生器的随机字符串。

var _list = "abcdefghijklmnopqrstuvwxyz9876543210"; 
 
function randomStringGenerator(how_long) {
    var tmp = '', i = 0;
    var list_len = _list.length;
     
    for (i = 0; i < how_long; i++) {
        tmp += _list.charAt(Math.floor(Math.random() * list_len));
    }
   
    return tmp;
}
 
alert(randomStringGenerator(8));

实现基于输入的字符列表(它可以是任何调整)。

1.5 Binary search(二分查找)

基于“分而治之”,二叉搜索一个简单但最优方法找到价值甚至在大输入列表。

在JavaScript的例子——二进制搜索:

inputList = new Array();
inputList[0] = 'E';
inputList[1] = 'I';
inputList[2] = 'O';
inputList[3] = 'P';
inputList[4] = 'Q';
inputList[5] = 'R';
inputList[6] = 'T';
inputList[7] = 'U';
inputList[8] = 'W';
inputList[9] = 'Y';
 
function binarySearch(inputList, key) {
    var left = 0;
    var right = inputList.length - 1;
   
    while (left <= right) {
        var mid = parseInt((left + right) / 2);
         
        if (inputList[mid] == key)
            return mid;
        else if (inputList[mid] < key)
            left = mid + 1;
        else
            right = mid - 1;
    }
   
    return 'Not found';
}
 
alert(binarySearch(inputList, 'T'));
alert(binarySearch(inputList, 'Z')); // Not found

参见:计算复杂性

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,211评论 0 4
  • 9.3.3 快速排序   快速排序将原数组划分为两个子数组,第一个子数组中元素小于等于某个边界值,第二个子数组中的...
    RichardJieChen阅读 1,833评论 0 3
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,598评论 18 139
  • LBSideslipCell 自定义tableViewCell侧滑按钮 自定义的UITableViewCell侧滑...
    悲伤的盖茨比阅读 1,160评论 0 1
  • 在2015年3月6号进入职场的喔,到现在为止已经经历了644个日日夜夜,犹记得那年一过年就早早的出了老家...
    孤狼啸月_阅读 257评论 0 2