给定数组,编写一个查找最大值并返回匹配字符串的函数

Posted

技术标签:

【中文标题】给定数组,编写一个查找最大值并返回匹配字符串的函数【英文标题】:Given array, write a function that finds the max and return the matching string 【发布时间】:2021-01-25 10:55:00 【问题描述】:

我得到了一个数组,需要编写一个函数 mostExpensiveItemName(items) 并让它返回数组中的最大数字并返回项目名称。

示例输出:

mostExpensiveItemName(items) //=> "Creation 3005"

给定数组:

let items = [
  
    itemName: "Effective Programming Habits",
    type: "book",
    price: 13.99
  ,
  
    itemName: "Creation 3005",
    type: "computer",
    price: 299.99
  ,
  
    itemName: "Finding Your Center",
    type: "book",
    price: 15.00
  
]

我有什么:

function mostExpensiveItemName(items) 
  if (items.length === 0) return undefined;
  let mostExpensive = items.reduce((total, items) => items.price > total.price ? items : total);

  return mostExpensive.itemName;

我的解决方案有效,但我想知道是否有一种超级基本的编写方式。使用 for 循环或 max() 方法

【问题讨论】:

你所拥有的似乎已经足够了。 我还要说您的解决方案是可行的方法。它很短,很容易阅读(即使我将 (total, items) 重命名为 (curMax, item))并且运行在 O(n) 中。我会考虑将它抽象一层,创建一个customMax(items, item => item.price) 方法,特别是如果您在多个场合使用它。 【参考方案1】:

您可以尝试升序 sort 并选择最后一个元素

let items = [
  
    itemName: "Effective Programming Habits",
    type: "book",
    price: 13.99,
  ,
  
    itemName: "Creation 3005",
    type: "computer",
    price: 299.99,
  ,
  
    itemName: "Finding Your Center",
    type: "book",
    price: 15.0,
  ,
]

function mostExpensiveItemName(items) 
  return (items.sort((a, b) => a.price - b.price).pop() || ).itemName


console.log(mostExpensiveItemName(items))
console.log(mostExpensiveItemName([]))

【讨论】:

以上是关于给定数组,编写一个查找最大值并返回匹配字符串的函数的主要内容,如果未能解决你的问题,请参考以下文章

在数组中查找匹配或最接近的值

从数组中查找并返回第一个匹配的子文档(Meteor / Mongo)

需要帮助编写一个函数来查找 N 维数组 C++ 中的最大值和最小值

Lua 正则表达式

CSDN|每日一练查找整数

CSDN|每日一练查找整数