10分钟题解-匹配规则的数量

171 阅读1分钟

题目1773:统计匹配检索规则的物品数量

这个题其实做对之后比较简单,之所以写题解,是因题目不好懂,然后做的时候就很容易因为题意理解不到位而做错题。

题目描述

给你一个数组 items ,其中 items[i] = [typei, colori, namei] ,描述第 i 件物品的类型、颜色以及名称。

另给你一条由两个字符串 ruleKey 和 ruleValue 表示的检索规则。

如果第 i 件物品能满足下述条件之一,则认为该物品与给定的检索规则 匹配 :

ruleKey == "type" 且 ruleValue == typei 。 ruleKey == "color" 且 ruleValue == colori 。 ruleKey == "name" 且 ruleValue == namei 。 统计并返回 匹配检索规则的物品数量 。

示例 1:

输入:items = [["phone","blue","pixel"],["computer","silver","lenovo"],["phone","gold","iphone"]], ruleKey = "color", ruleValue = "silver"
输出:1
解释:只有一件物品匹配检索规则,这件物品是 ["computer","silver","lenovo"] 。

示例 2:


输入:items = [["phone","blue","pixel"],["computer","silver","phone"],["phone","gold","iphone"]], ruleKey = "type", ruleValue = "phone"
输出:2
解释:只有两件物品匹配检索规则,这两件物品分别是 ["phone","blue","pixel"] 和 ["phone","gold","iphone"] 。注意,["computer","silver","phone"] 未匹配检索规则。

题解:

items 是一个二维数组,它的元素也是一个数组,而且这个元素数组的值是有规律的。这是题目的关键。

/**

 \* @param {string[][]} items

 \* @param {string} ruleKey

 \* @param {string} ruleValue

 \* @return {number}

 */

var countMatches = function(items, ruleKey, ruleValue) {

  var x = 0;

  var kvs = {"type":0,"color":1,"name":2}

  items.forEach((item,index) => {

​    item[kvs[ruleKey]]==ruleValue && x++

  })

  return x;

};

其实此题就是要理解数组索引规则,制定好规则就很容易做出来,难点就在理解题意。

参考链接:leetcode-cn.com/problems/co…