freeCodeCamp/curriculum/challenges/chinese/08-coding-interview-prep/data-structures/create-a-map-data-structure...

4.4 KiB
Raw Blame History

id title challengeType videoUrl localeTitle
8d5823c8c441eddfaeb5bdef Create a Map Data Structure 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")})(), "The Map data structure exists.");'
  - 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")})(), "The Map object has the following methods: add, remove, get, has, values, clear, and size.");'
  - 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)})(), "The add method adds items to the map.");'
  - 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"))})(), "The has method returns true for added items and false for absent items.");'
  - text: get方法接受键作为输入并返回关联的值。
    testString: 'assert((function() { var test = false; if (typeof Map !== "undefined") { test = new Map() }; test.add("abc","def"); return (test.get("abc") == "def")})(), "The get method accepts keys as input and returns the associated values.");'
  - 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)})(), "The values method returns all the values stored in the map as strings in an array.");'
  - 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)})(), "The clear method empties the map and the size method returns the number of items present in the map.");'

Challenge Seed

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

Solution

// solution required