飞镖列表最小值/最大值

Posted

技术标签:

【中文标题】飞镖列表最小值/最大值【英文标题】:Dart List min/max value 【发布时间】:2013-12-27 18:10:35 【问题描述】:

如何在 Dart 中获取 List 的最小值和最大值。

[1, 2, 3, 4, 5].min //returns 1
[1, 2, 3, 4, 5].max //returns 5

我确定我可以 a) 编写一个简短的函数或 b) 复制然后对列表进行排序并选择最后一个值,

但我正在寻找是否有更原生的解决方案。

【问题讨论】:

【参考方案1】:
int minF() 
  final mass = [1, 2, 0, 3, 5];
  mass.sort();
  
  return mass[0];

【讨论】:

【参考方案2】:

如果您的列表为空,reduce 将抛出错误。

您可以使用fold 代替reduce

// nan compare to any number will return false
final initialValue = number.nan;
// max
values.fold(initialValue, (previousValue, element) => element.value > previousValue ? element.value : previousValue);
// min
values.fold(initialValue, (previousValue, element) => element.value < previousValue ? element.value : previousValue);

它也可以用来计算总和。

final initialValue = 0;
values.fold(initialValue, (previousValue, element) => element.value + previousValue);

虽然fold 在获取最小值/最大值方面并不比reduce 干净,但它仍然是一种执行更灵活操作的强大方法。

【讨论】:

【参考方案3】:

根据地图对象列表的条件使用 reduce 获取最小值/最大值的示例

Map studentA = 
  'Name': 'John',
  'Marks': 85
;

Map studentB = 
  'Name': 'Peter',
  'Marks': 70
;

List<Map> students = [studentA, studentB];

// Get student having maximum mark from the list

Map studentWithMaxMarks = students.reduce((a, b) 
    if (a["Marks"] > b["Marks"])
        return a;
    else
        return b;
);


// Get student having minimum mark from the list (one liner)

Map studentWithMinMarks = students.reduce((a, b) => a["Marks"] < b["Marks"] ? a : b);

另一个使用 reduce 根据类对象列表的条件获取最小值/最大值的示例

class Student 
    final String Name;
    final int Marks;

    Student(this.Name, this.Marks);


final studentA = Student('John', 85);
final studentB = Student('Peter', 70);

List<Student> students = [studentA, studentB];

// Get student having minimum marks from the list

Student studentWithMinMarks = students.reduce((a, b) => a.Marks < b.Marks ? a : b);

【讨论】:

【参考方案4】:

对于空列表:如果列表为空,则返回 0,否则返回最大值。

  List<int> x = [ ];  
  print(x.isEmpty ? 0 : x.reduce(max)); //prints 0

  List<int> x = [1,32,5];  
  print(x.isEmpty ? 0 : x.reduce(max)); //prints 32

【讨论】:

【参考方案5】:

假设列表不为空,您可以使用Iterable.reduce:

import 'dart:math';

main()
  print([1,2,8,6].reduce(max)); // 8
  print([1,2,8,6].reduce(min)); // 1

【讨论】:

列表可以为空怎么办?有没有办法避免检查空虚? 你可以做[maxOnEmpty, ...list].reduce(max) 谢谢,但我已经找到了更清洁的解决方案。 [1,2,8,6].fold(0, max) 会成功的。 似乎这仍然不适用于空列表...例如[].fold(0, max) 引发错误。 @AlexSemeniuk @PROgram52bc 您是否正确指定了列表类型?【参考方案6】:

您现在可以使用an extension as of Dart 2.6 实现此目的:

import 'dart:math';

void main() 
  [1, 2, 3, 4, 5].min; // returns 1
  [1, 2, 3, 4, 5].max; // returns 5


extension FancyIterable on Iterable<int> 
  int get max => reduce(math.max);

  int get min => reduce(math.min);

【讨论】:

【参考方案7】:

如果您不想导入dart: math,但仍想使用reduce

main() 
  List list = [2,8,1,6]; // List should not be empty.
  print(list.reduce((curr, next) => curr > next? curr: next)); // 8 --> Max
  print(list.reduce((curr, next) => curr < next? curr: next)); // 1 --> Min

【讨论】:

为什么人们会非常喜欢这种方法? @MateusFelipe 您可以将其作为函数传递,与 math.max 或 min 一样,我遇到了一些麻烦。 那么,提供您的方法的特定用例是个好主意,因为它似乎是一个非常边缘的案例。 这实际上是一个有用的评论。只要列表是对象列表而不是(字符串,数字)列表,我们就不能直接使用 dart:math。我们必须做一些类似“curr.id 没错,它非常有用。例如,我将它用于 DateTime:dates.reduce((current, next) =&gt; current.compareTo(next) &gt; 0 ? current : next) 最接近 LINQ 类语法。

以上是关于飞镖列表最小值/最大值的主要内容,如果未能解决你的问题,请参考以下文章

[基础] 在Python中获得字典列表中最大值与最小值

python寻找列表最大值最小值及其下标

使用列表值获取 dict 的最大值和最小值

在pyspark中查找列表的最大值/最小值

使用带有最小值和最大值的 jQuery 验证体验下拉列表

列表中的 Python 平均值、最大值、最小值