亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

求助,一個linq的查詢問題

求助,一個linq的查詢問題

慕桂英4014372 2018-08-23 10:09:34
詳見代碼static void Main(string[] args){    List<ScoreModel> scoreList = new List<ScoreModel>(){        new ScoreModel(){Id = 1, Score = 30},        new ScoreModel(){Id = 2, Score = 20},        new ScoreModel(){Id = 3, Score = 30},        new ScoreModel(){Id = 4, Score = 20},        new ScoreModel(){Id = 5, Score = 15},        new ScoreModel(){Id = 6, Score = 10},        new ScoreModel(){Id = 7, Score = 30},        new ScoreModel(){Id = 8, Score = 40},    };    int userScore = 33;    var result = from i in scoreList                    where [how to?]                    select i;                    //獲取i.score小于userScore的最大值                    //即所有小于33的列表中取出最大值30的3個元素                    //期望結果:包含三個元素id=1,3,7的List<ScoreModel>}class ScoreModel{    public int Id { get; set; }    public int Score { get; set; }}
查看完整描述

1 回答

?
慕哥6287543

TA貢獻1831條經驗 獲得超10個贊

var result = (from x in scoreList              where x.Score < userScore
              group x by x.Score into g              orderby g.Key descending              select g).First();
//或者用

var result2 = scoreList.Where(x => x.Score < userScore)
       .GroupBy(x => x.Score)
       .OrderByDescending(g => g.Key)
       .First();


查看完整回答
反對 回復 2018-09-12
  • 1 回答
  • 0 關注
  • 776 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號