题解 | #最高售价的两只牛#

最高售价的两只牛

https://www.nowcoder.com/practice/8e4a09d5f63d4298a8507decf5d12490

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param pricesA int整型一维数组 
     * @param pricesB int整型一维数组 
     * @param k int整型 
     * @return int整型二维数组
     */
  
  	/**
	 * 创建结点,用于存放下标和累加值
	 * 建立大根堆
  	 */
    static class Node{
        int a,b,sum;
        Node(int a,int b,int sum){
            this.a = a;
            this.b = b;
            this.sum = sum;
        }
    }

    public int[][] kPairsWithLargestSums (int[] pricesA, int[] pricesB, int k) {
	  //优先队列
        PriorityQueue<Node> que = new PriorityQueue<Node>((a, b)->{
            //售价一致时,A组优先
            if(b.sum==a.sum) return pricesA[b.a]-pricesA[a.a];
		  //售价最高优先
            return b.sum-a.sum;});
        int m = pricesA.length,n=pricesB.length;
	  //首先将A所有值和B组最大值组合,入堆,
	  //此时得到的堆一定是各个以A优先组合的最大值
        for(int i=0;i<m;i++){
            que.add(new Node(i,n-1,pricesA[i]+pricesB[n-1]));
        }
        ArrayList<List<Integer>> res = new ArrayList<>();
        while(k-->0 && !que.isEmpty()){
            Node t = que.poll();;
            // System.out.println(Arrays.asList(pricesA[t.a],pricesB[t.b]));
		  //取堆顶最大值进入结果集
            res.add(Arrays.asList(pricesA[t.a],pricesB[t.b]));
            if(t.b>0){
			  //取出B组下标向前移动1
                t.b--;
                t.sum = pricesA[t.a]+pricesB[t.b];
			  //入堆,此节点必然小于先前结点,入堆后由先前定义的compare维护
                que.add(t);
            }
        }
	  //转换为int[][]
        int l =  res.size();
        int[][] result = new int[l][2];
        for(int i=0;i<l;i++){
            for(int j=0;j<2;j++){
                result[i][j] = res.get(i).get(j);
                
            }
        }
        return result;
    }
}

面试高频TOP202 文章被收录于专栏

面试高频TOP202题解

全部评论

相关推荐

感觉他们一点都不了解现在这个社会就业有多难,已经在牛客刷到好多篇&nbsp;延毕的帖子了,延毕就会导致已经找好的工作就没了,还得重新再找,学校和老师们是怎么想的呢????看到学生丢失工作会开心吗&nbsp;就业数据都在造假,真实的就业困难不去解决&nbsp;一个个真是好样的
从明天开始狠狠卷JV...:学生看到的是导师不放实习导致offer黄了。 导师看到的是招进来的学生吃自己补助和自己的招生名额,却没给自己升迁带来任何帮助,还要跑路。 根本利益的不一致,最主要留校的导师大概率是职场上招聘失败的,被迫留校的,什么牛鬼蛇神都会有
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务