劍指offer之陣列中出現次數超過一半的數字
阿新 • • 發佈:2018-10-31
1.題目描述
陣列中有一個數字出現的次數超過陣列長度的一半,請找出這個數字。例如輸入一個長度為9的陣列{1,2,3,2,2,2,5,4,2}。由於數字2在陣列中出現了5次,超過陣列長度的一半,因此輸出2。如果不存在則輸出0。
2.問題分析
- 方法一:使用map,統計每個數字的次數,之後查詢是否有次數超過陣列長度的一半的數字;
- 如果有符合條件的數字,則它出現的次數比其他所有數字出現的次數和還要多。
在遍歷陣列時儲存兩個值:一是陣列中一個數字,一是次數。遍歷下一個數字時,若它與之前儲存的數字相同,則次數加1,否則次數減1;若次數為0,則儲存下一個數字,並將次數置為1。遍歷結束後,所儲存的數字即為所求。然後再判斷它是否符合條件即可。
3.原始碼
方法一:
int MoreThanHalfNum_Solution(vector<int> numbers)
{
if(numbers.size() == 0)
return 0;
map<int,int> times;
for(int value:numbers)
{
++times[value];
}
for(auto& time:times)
{
if (time.second > numbers.size() / 2)
return time.first;
}
return 0;
}
方法二:
int MoreThanHalfNum_Solution(vector<int> numbers) {
int len = numbers.size();
if(len == 0)
return 0;
int result = numbers[0];
int times = 1;
for (int i = 1; i < len; ++i)
{
if(times == 0)
{
result = numbers[i];
times = 1;
}
else
{
if(result == numbers[i])
++times;
else
--times;
}
}
times = 0;
for(int i = 0; i < len; ++i)
{
if(result == numbers[i])
++times;
}
if(times <= len / 2)
result = 0;
return result;
}