從該數組中返回已開始但未結束的 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 關注
- 197 瀏覽
添加回答
舉報
0/150
提交
取消