0
点赞
收藏
分享

微信扫一扫

第十五届蓝桥杯第三期模拟赛第十题 ← 上楼梯

程序员知识圈 04-01 07:31 阅读 3
算法java

完成一半题目

有 N 位扣友参加了微软与力扣举办了「以扣会友」线下活动。主办方提供了 2*N 道题目,整型数组 questions 中每个数字对应了每道题目所涉及的知识点类型。 若每位扣友选择不同的一题,请返回被选的 N 道题目至少包含多少种知识点类型。

示例 1:

示例 2:

提示:

  • questions.length == 2*n
  • 2 <= questions.length <= 10^5
  • 1 <= questions[i] <= 1000

我的解答

将知识点类型和在2N道题中出现的次数储存在哈希表中,类型为key,次数为value

再将哈希表根据value从大到小排序

根据value的累加和与N比较,大于等于时,看看是第几个value,即可判断知识点的类型

第一次解答错误,因为在存储次数times,下一个知识点类型的times未置1

完整代码,哈希表根据value从大到小排序还是网上借鉴的,还是不太建议用这个思路做吧

Java HashMap按key排序和按value排序的两种简便方法

class Solution {
    public int halfQuestions(int[] questions) {

        //将每种类型及其对应出现的次数存到哈希表中
        HashMap<Integer,Integer> h=new HashMap<Integer,Integer>();
        int i=0,j=0,times=1;
        for(i=0;i<questions.length;i++){
            if(questions[i]==0)
            continue;
            for(j=i+1;j<questions.length;j++){
                if(questions[i]==questions[j]){
                    times=times+1;
                    questions[j]=0;
                }
            }
            h.put(questions[i],times);
            times=1;
        }

         List<HashMap.Entry<Integer, Integer>> list = new ArrayList<HashMap.Entry<Integer, Integer>>(h.entrySet()); //转换为list
                list.sort(new Comparator<HashMap.Entry<Integer, Integer>>() {
          @Override
          public int compare(HashMap.Entry<Integer, Integer> o1, HashMap.Entry<Integer, Integer> o2) {
              return o2.getValue().compareTo(o1.getValue());
          }
      });
    int sum=0;
    for(i=0;i<list.size();i++){

        sum=sum+list.get(i).getValue();
        if(sum>=questions.length/2){
            return i+1;
        }
    }

return -1;



    }
}

 

举报

相关推荐

0 条评论