按重复元素颤振对列表进行排序
Sort a list by repeated elements flutter
我需要按照重复元素最多的方式对数组进行排序,如下所示:
List<String> list = ['x','y','z','x','y','y']
期望的输出:
[y,y,y,x,x,z]
您可以使用排序功能来完成。这是一个工作示例:
void main() {
List list = ['x', 'y', 'z', 'x', 'y', 'y'];
List copyList = List.from(list);
list.sort((var a, var b) {
int numberOfA = copyList.where((element) => element == a).length;
int numberOfB = copyList.where((element) => element == b).length;
return numberOfB.compareTo(numberOfA);
});
print(list);
}
其他使用排序函数的例子:
void main() {
List list = ['x', 'y', 'z', 'x', 'y', 'y'];
list.sort((a, b) => b.compareTo(a),);
}
有关 compareTo
的更多信息
我建议将频率计算移到排序循环之外。
void main() {
List<String> list = ['x', 'y', 'z', 'x', 'y', 'y'];
Map<String, int> numberOf = {
for (var x in list.toSet()) x: list.where((item) => item == x).length
};
print(list..sort((a, b) => numberOf[b]!.compareTo(numberOf[a]!)));
}
控制台日志
[y, y, y, x, x, z]
我需要按照重复元素最多的方式对数组进行排序,如下所示:
List<String> list = ['x','y','z','x','y','y']
期望的输出:
[y,y,y,x,x,z]
您可以使用排序功能来完成。这是一个工作示例:
void main() {
List list = ['x', 'y', 'z', 'x', 'y', 'y'];
List copyList = List.from(list);
list.sort((var a, var b) {
int numberOfA = copyList.where((element) => element == a).length;
int numberOfB = copyList.where((element) => element == b).length;
return numberOfB.compareTo(numberOfA);
});
print(list);
}
其他使用排序函数的例子:
void main() {
List list = ['x', 'y', 'z', 'x', 'y', 'y'];
list.sort((a, b) => b.compareTo(a),);
}
有关 compareTo
的更多信息我建议将频率计算移到排序循环之外。
void main() {
List<String> list = ['x', 'y', 'z', 'x', 'y', 'y'];
Map<String, int> numberOf = {
for (var x in list.toSet()) x: list.where((item) => item == x).length
};
print(list..sort((a, b) => numberOf[b]!.compareTo(numberOf[a]!)));
}
控制台日志
[y, y, y, x, x, z]