- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试从基于多个属性的学生对象列表中删除重复项,同时保留顺序,如下所示,我有学生对象列表,其中我们有多个同名学生,但出勤率不同……我需要删除重复项具有相同名称且学生出席人数为 100 的学生,同时保留顺序。
Student{studentId=1, studentName='Sam', studentAttendence=100, studentAddress='New York'}
Student{studentId=2, studentName='Sam', studentAttendence=50, studentAddress='New York'}
Student{studentId=3, studentName='Sam', studentAttendence=60, studentAddress='New York'}
Student{studentId=4, studentName='Nathan', studentAttendence=40, studentAddress='LA'}
Student{studentId=5, studentName='Ronan', studentAttendence=100, studentAddress='Atlanta'}
Student{studentId=6, studentName='Nathan', studentAttendence=100, studentAddress='LA'}
删除重复项后的期望输出:
Student{studentId=2, studentName='Sam', studentAttendence=50, studentAddress='New York'}
Student{studentId=3, studentName='Sam', studentAttendence=60, studentAddress='New York'}
Student{studentId=4, studentName='Nathan', studentAttendence=40, studentAddress='LA'}
Student{studentId=5, studentName='Ronan', studentAttendence=100, studentAddress='Atlanta'}
我现在所拥有的只是根据名称删除重复项而不考虑百分比(100)......并且也不保留顺序......非常感谢任何帮助。(学生供应商是学生名单的简单供应商功能)
studentsSupplier.get().stream()
.sorted(Comparator.comparing(Student::getStudentName))
.collect(Collectors.collectingAndThen(
Collectors.toCollection(
() -> new TreeSet<>(Comparator.comparing(Student::getStudentName))), ArrayList::new));
注意:只有学生姓名匹配且百分比为100的重复记录必须删除,(记录Ronon有百分比100但没有重复的学生姓名相同,因此不能删除)
最佳答案
如果你想保留顺序,显然不要打电话.sorted
,这扰乱了秩序。
更普遍地在这里使用流是复杂的。如果您想对流中的每个元素执行的操作是独立的(除了正在考虑的一个元素之外,不需要查看任何内容,即不需要查看邻居),则类似流。这不是这里的情况。
如果删除任何出勤率为 100 的学生是正确的(顺便说一句,这是一个错字,正确的词是出勤),那么所有这些关于“重复”的东西都是一个红鲱鱼,你只需要:
list.removeIf(s -> s.getStudentAttendence() >= 100);
但如果想法是:仅当出席人数超过 100 人时才删除记录,
和 列表中至少有一个其他记录具有相同的名称,它变得更加复杂。
List
)也不提供任何快速查找;没有办法编写代码来回答这个问题“有多少条学生姓名记录
Sam
”。是否在此列表中?)而无需遍历 1 亿个条目,这是一项非常重要的工作。
List
形式。 Sam
会发生什么?学生和每条记录都有
studentAttendence = 100
?他们都应该被删除吗?不应该删除吗?删除 2 个任意的?
List<Students> students = ...;
Set<String> dupeNames = students.stream()
.filter(s -> s.getAttendence() < 100)
.map(Student::getStudentName)
.collect(Collectors.toSet());
students.removeIf(s -> s.getAttendence() < 100 && dupeNames.contains(s.getStudentName());
会完成工作,并且会很快完成。 (O(n),在算法上是特定的:制作基于集合的副本需要每个学生记录的固定时间步长,因此 O(n) 和 removeIf 调用同样需要检查每个学生,但只需要执行固定时间每步工作,因为
.contains()
在集合上是恒定时间,假设良好的散列分布,字符串通常具有),因此,恒定数量的 O(n) 操作意味着整个操作是 O(n):所需的时间随输入列表中有多少学生线性增长(与每次处理列表中的单个条目时都扫描整个列表的解决方案相比,该条目随输入大小的平方增长)。
关于Java 8 :How to remove duplicates from the List based on multiple properties preserving the order,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67299144/
我有一个内部表,里面有 108 个条目。从 9 到 9 个条目重复条目,我想删除这些重复项。由于它们完全相同,我使用了 delete adjacent duplicates from itab com
在 Team Foundation Server (TFS) 中链接两个工作项 (WI) 时,在什么情况下将“Duplicate”和“Duplicate Of”区分为“链接类型”是有意义的? 如何处理
ld: duplicate symbol _velocityX in \ /Users/Student/Library/Developer/Xcode/DerivedData/finalproject
我使用 PHP 和 Mysql。 此 SQL 有效: INSERT INTO products (id, title, description) VALUES (10, 'va
我有一个大数据框 (120000x40),我尝试在每一行中找到重复项并显示它们。这就是我的尝试: 创建数据框 import pandas as pd df = pd.DataFrame({'col1'
我是 mySQL 和 PHP 的新手,请多多包涵。 如果我的查询有重复字段,我该如何做到这一点,检索到的数据将具有重复查询字段的重复数据。 一个例子是这样的: 查询 id = 34, 54, 21,
我一直遇到这个错误,但我无法理解它,因为它提示一个值恰好出现一次。 Exception in thread "main" java.lang.IllegalStateException: Duplic
我有一个带有 Vuejs 和 Laravel 的 Web 应用程序 我想使用 CKEditor 5 我安装了依赖项 npm install --save @ckeditor/ckeditor5-vue
我有一个包含以下数据的 csv 文件: Id,Name,Type,date 1,name1,employee,25/04/2017 2,name2,contrator,26/04/2017 3,nam
import CKEditor from '@ckeditor/ckeditor5-react'; import ClassicEditor from '@ckeditor/ckeditor5-bui
表定义: CREATE TABLE PositionalDataNGS ( Date DATE, Time TIME(3) , X FLOAT(5), Y FLOAT(5), D FLOAT(5) ,
我目前正在做一个项目,我要处理数以千计的数据包。现在,我记录每个数据包的 IP 和 MAC 地址以及一些其他信息。为了存储所有这些,我使用 MySQL 并且我的脚本是用 Node.js 编写的。目前我
I am using MySQL 5.1.56, MyISAM. My table looks like this:我使用的是MySQL 5.1.56,MyISAM。我的桌子是这样的: CR
我是新来的,对 SQL 比较陌生。我有一个类似这样的表: [Pk], [Case_No], [Status], [Open_Date], [Close_Date], [Case_Age], [Repo
为什么会收到此警告? warning No duplicate props allowed react/jsx-no-duplicate-props# 它显示的是第28行,但没有使用 Prop 。 最
是否有任何函数或方法可以在 python 2.7 中递归实现此目的? Input : ['and', ['or', 'P', '-R', 'P'], ['or', '-Q', '-R', 'P']]
我正在分析 hadoop 中的数据。有一些重复条目,其中 A、B 列重复,而 C 列不同。我想要做的是仅识别 A、B 重复项,然后为每个重复项打印出 C 列的不同值。 示例数据: row, data
您好,感谢阅读并可能对我有所帮助 我的问题的简要说明: 我正在将数据从一个 Firebird 数据库复制到另一个(称为 V14),并且我正在使用 IBExpert 来执行此操作。这些表的名称相同并且具
我想制作一张很像下面的图片: 我想使用 seaborn 使图表看起来漂亮,并让我自己以后更容易使用 facetgrids(我有十个不同的数据集,我想在同一个图表中显示。) 我在 seaborn 中找到
我在两列“user_id”和“project_id”上有一个复合唯一键。 当我尝试对单行或多行运行 DELETE 查询时,出现错误。 ERROR 1062: 1062: Duplicate entry
我是一名优秀的程序员,十分优秀!