2020-10-06 23:10:08 +05:30

3.8 KiB
Raw Blame History

id, challengeType, videoUrl, title
id challengeType videoUrl title
8d5823c8c441eddfaeb5bdef 1 创建地图数据结构

Description

接下来的几个挑战将涵盖地图和哈希表。映射是存储键值对的数据结构。在JavaScript中我们可以将它们作为对象使用。地图可根据键值快速查找存储的项目是非常常见且有用的数据结构。说明让我们开始创建自己的地图。因为JavaScript对象提供了比我们在此处编写的任何内容更有效的地图结构所以这主要是作为学习练习。但是JavaScript对象仅向我们提供某些操作。如果我们想定义自定义操作怎么办使用此处提供的Map对象作为JavaScript object的包装器。在Map对象上创建以下方法和操作
  • add接受要添加到地图的key, value对。
  • remove接受一个键并删除关联的key, value
  • get接受一个key并返回存储的value
  • 如果密钥存在has接受key并返回true否则返回false
  • values返回地图中所有values的数组
  • size返回地图中的项目数
  • clear清空地图

Instructions

Tests

tests:
  - text: 存在地图数据结构。
    testString: assert((function() { var test = false; if (typeof Map !== 'undefined') { test = new Map() }; return (typeof test == 'object')})());
  - text: Map对象具有以下方法addremovegethasvaluesclear和size。
    testString: "assert((function() { var test = false; if (typeof Map !== 'undefined') { test = new Map() }; return (typeof test.add == 'function' && typeof test.remove == 'function' && typeof test.get == 'function' && typeof test.has == 'function' && typeof test.values == 'function' && typeof test.clear == 'function' && typeof test.size == 'function')})());"
  - text: add方法将项添加到地图中。
    testString: assert((function() { var test = false; if (typeof Map !== 'undefined') { test = new Map() }; test.add(5,6); test.add(2,3); test.add(2,5); return (test.size() == 2)})());
  - text: has方法对于添加的项返回true对于缺少的项返回false。
    testString: assert((function() { var test = false; if (typeof Map !== 'undefined') { test = new Map() }; test.add('test','value'); return (test.has('test') && !test.has('false'))})());
  - text: get方法接受键作为输入并返回关联的值。
    testString: assert((function() { var test = false; if (typeof Map !== 'undefined') { test = new Map() }; test.add('abc','def'); return (test.get('abc') == 'def')})());
  - text: values方法将存储在映射中的所有值作为数组中的字符串返回。
    testString: assert((function() { var test = false; if (typeof Map !== 'undefined') { test = new Map() }; test.add('a','b'); test.add('c','d'); test.add('e','f'); var vals = test.values(); return (vals.indexOf('b') != -1 && vals.indexOf('d') != -1 && vals.indexOf('f') != -1)})());
  - text: clear方法清空映射size方法返回映射中存在的项目数。
    testString: assert((function() { var test = false; if (typeof Map !== 'undefined') { test = new Map() }; test.add('b','b'); test.add('c','d'); test.remove('asdfas'); var init = test.size(); test.clear(); return (init == 2 && test.size() == 0)})());

Challenge Seed

var Map = function() {
  this.collection = {};
  // change code below this line
  // change code above this line
};

Solution

// solution required

/section>