题解 | #数组中出现次数超过一半的数字#
数组中出现次数超过一半的数字
https://www.nowcoder.com/practice/e8a1b01a2df14cb2b228b30ee6a92163
#include <unordered_map> class Solution { public: /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param numbers int整型vector * @return int整型 */ int MoreThanHalfNum_Solution(vector<int>& numbers) { // value , count std::unordered_map<int, int> hash_map; for (int i = 0; i < numbers.size(); ++i) { hash_map[numbers[i]] ++; } for (auto kv: hash_map) { if (kv.second > numbers.size()/2){ return kv.first; } } return -1; } };
先用 hash map去记录 数组中的元素和出现的次数; 其中 key =数组的元素, value是出现的次数
然后遍历, 将第一个满足条件的元素返回
note_coding 文章被收录于专栏
记录自己的解题思路, 欢迎评价