从该数组中返回已开始但未结束的 ID 的最佳方法是什么。我一直在尝试循环匹配 ID,然后检查状态是“开始”还是“结束”,但我一直与我选择进行排序的 ID 和状态匹配。(即,我选择 array[0,0] 并查找 ID 5847 它将获得匹配本身)。array[0,0] = "5847"array[0,1] = "started"array[1,0] = "5846"array[1,1] = "ended"array[2,0] = "5846"array[2,1] = "started"array[3,0] = "5845"array[3,1] = "ended"array[4,0] = "5845"array[4,1] = "started"array[5,0] = "5844"array[5,1] = "ended"
1 回答
FFIVE
TA贡献1797条经验 获得超6个赞
将您的 2D 投影到一个对象中,因为您似乎拥有基于行的对象。
然后根据ID分组,取Ended=1/Started=0的最大值
var result =
Enumerable
.Range(0, array.GetLength(0))
.Select(row => new Foo { id = int.Parse(array[row, 0]), ended = (array[row, 1] == "ended") })
.GroupBy(g=> g.id)
.Select( g=> new { Id=g.Key, MaxEnded= g.Max(r=> r.ended)})
.Where(x=> !x.MaxEnded);
- 1 回答
- 0 关注
- 178 浏览
添加回答
举报
0/150
提交
取消