map<int,int> 计数器; counter[nums[i]]++;
map<int,int> counter; counter[nums[i]]++;
我在leetcode上看到了这段代码,找到多数元素是一个问题。以下是问题描述:
给定一个大小为 n 的数组,找到多数元素。多数元素是出现超过 ⌊ n/2 ⌋ 次的元素。
您可以假设数组是非空的,并且数组中始终存在多数元素。
在讨论这些代码时有一个答案:
class Solution
{
public:
int majorityElement(vector<int>& nums)
{
map<int, int> cnt;
for(int i=0; i < nums.size(); i++)
cnt[ nums[i] ]++;
int n = nums.size();
for(map<int, int>::iterator iter=cnt.begin(); iter!=cnt.end();iter++)
if( iter->second > n/2 )
return iter->first;
}
};
所以我对这一行很好奇:cnt[ nums[i] ]++;
我不需要先初始化 cnt[nums[i]]=0 吗?我想我需要先这样做,否则会有内存泄漏,因为没有 key nums[i] 的现有值来执行 ++。我错了吗?
std::map::operator[]
被定义为默认初始化给定键的值,如果已经不存在这样的值。从标准; [map.access]
:
T& operator[](const key_type& x);
1 效果:如果映射中没有等效于 x 的键,则在映射中插入 value_type(x, T())。
对于int
,默认值是0
,所以不需要做进一步的工作。
相关文章:
- 为什么在全局范围内使用"extern int a"似乎不行?
- int(c) 和 c-'0' 之间的区别。C++
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 是否可以从int转换为enum类类型
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 'short int'持有的值溢出,但"自动"不会溢出?
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- 调用'begin(int [n])'没有匹配函数
- 没有显式声明的int[]中的foreach
- 在c++中访问int到类对象的映射时出错
- 为什么我无法更改"set<set>"循环中的值<int>
- 长 长 int 不要 长 int 好
- C++程序在循环后给出奇怪的int值
- 如何计算数据类型的范围,例如int
- map<int,int> 计数器; counter[nums[i]]++;
- 代码"int nums[5]"做什么?