日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

leetcode 781. 森林中的兔子(hashmap)

發(fā)布時(shí)間:2023/11/29 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 leetcode 781. 森林中的兔子(hashmap) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

森林中,每個(gè)兔子都有顏色。其中一些兔子(可能是全部)告訴你還有多少其他的兔子和自己有相同的顏色。我們將這些回答放在 answers 數(shù)組里。

返回森林中兔子的最少數(shù)量。

示例:
輸入: answers = [1, 1, 2]
輸出: 5
解釋:
兩只回答了 “1” 的兔子可能有相同的顏色,設(shè)為紅色。
之后回答了 “2” 的兔子不會(huì)是紅色,否則他們的回答會(huì)相互矛盾。
設(shè)回答了 “2” 的兔子為藍(lán)色。
此外,森林中還應(yīng)有另外 2 只藍(lán)色兔子的回答沒有包含在數(shù)組中。
因此森林中兔子的最少數(shù)量是 5: 3 只回答的和 2 只沒有回答的。

輸入: answers = [10, 10, 10]
輸出: 11

輸入: answers = []
輸出: 0

解題思路

將具有報(bào)出相同數(shù)量同類的兔子作為一組,遍歷一次數(shù)組,就可以知道每個(gè)組內(nèi)缺了多少個(gè)兔子,再加上原數(shù)組中的兔子個(gè)數(shù),就是森林中兔子的最少數(shù)量。

代碼

class Solution {public int numRabbits(int[] answers) {HashMap<Integer, Integer> map = new HashMap<>();for (int i = 0; i < answers.length; i++) {if(answers[i]==0) continue; //獨(dú)一無二的兔子map.put(answers[i],map.getOrDefault(answers[i],answers[i]+1)-1);if(map.get(answers[i])==0) map.remove(answers[i]);//這個(gè)組已經(jīng)查完了,移除}int res=answers.length;for (Map.Entry<Integer, Integer> entry : map.entrySet()) {res+=entry.getValue();}return res;} }

總結(jié)

以上是生活随笔為你收集整理的leetcode 781. 森林中的兔子(hashmap)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。