duanlinzhen7235 2015-05-12 18:52
浏览 31
已采纳

PHP按值排序多个数组

I want to know how can i sort this in PHP in base of "leaguePoints" and then in "wins"

<?php
            foreach ($league as $leaguesList)
            {
                if ($leaguesList->queue == "RANKED_SOLO_5x5")
                {
                    foreach ($leaguesList as $list)
                    {
                       if ($list->division == $leagueSummoner->division){
                           $array[] = $list;
                       }
                    }
                }
            }

    var_dump($array);

Result: http://pastebin.com/QkKU7W0k

Im trying to port this from Java, wich i do in this way:

    public void setRankList(List<LeagueSummonerLeagueStats> _rankList) {

    rankList = _rankList;
    Collections.sort(rankList, new Comparator() {

        public int compare(Object match1Obj, Object match2Obj) {

            LeagueSummonerLeagueStats league1 = (LeagueSummonerLeagueStats) match1Obj;

            LeagueSummonerLeagueStats league2 = (LeagueSummonerLeagueStats) match2Obj;

            int i = Integer.compare(league2.getLeaguePoints(), league1.getLeaguePoints());

            if (i != 0)
                return i;

            i = Integer.compare(league2.getWins(), league1.getWins());

            if (i != 0)
                return i;

            return -1;
        }
    });
    }

Thank you very much for your time, i really appreciate your help.

  • 写回答

3条回答 默认 最新

  • doulupian8725 2015-05-12 19:05
    关注

    I don't like to normally provide solutions, but you just needed to port it to another language.

    Basically, you want to write a bubblesort callback, which will first compare two records wins properties, then if they are equal, fall back to the league points property. Something like

    $data = [
        [
            'wins' => 10,
            'leaguePoints' => 10,
        ],
        [
            'wins' => 10,
            'leaguePoints' => 20,
        ],
        [
            'wins' => 20,
            'leaguePoints' => 10,
        ],    
        [
            'wins' => 10,
            'leaguePoints' => 10,
        ],
    ];
    
    usort($data, function($a, $b)
    {
        if ($a['wins'] === $b['wins']) {
            if ($a['leaguePoints'] === $b['leaguePoints']) {
                return 0;
            }
    
            return ($a['leaguePoints'] > $b['leaguePoints']) ? -1 : 1;
        }
    
        return ($a['wins'] > $b['wins']) ? -1 : 1;
    });
    
    print_r($data);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 Vue3 大型图片数据拖动排序
  • ¥15 划分vlan后不通了
  • ¥15 GDI处理通道视频时总是带有白色锯齿
  • ¥20 用雷电模拟器安装百达屋apk一直闪退
  • ¥15 算能科技20240506咨询(拒绝大模型回答)
  • ¥15 自适应 AR 模型 参数估计Matlab程序
  • ¥100 角动量包络面如何用MATLAB绘制
  • ¥15 merge函数占用内存过大
  • ¥15 使用EMD去噪处理RML2016数据集时候的原理
  • ¥15 神经网络预测均方误差很小 但是图像上看着差别太大