面试题39:数组中出现次数超过一半的数字

数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。

解法一: 用于笔试
使用快排sort,时间复杂度为O(NlogN),并非最优
先排序,找出中间那个数; 计算中间数的出现次数,如果超过数组长度的一半,返回,否则返回0

class Solution {
public:
int MoreThanHalfNum_Solution(vector<int> numbers)
{
// 因为用到了sort,时间复杂度O(NlogN),并非最优
if(numbers.empty()) return ; sort(numbers.begin(),numbers.end()); // 排序,取数组中间那个数
int middle = numbers[numbers.size()/]; int count=; // 出现次数
for(int i=;i<numbers.size();++i)
{
if(numbers[i]==middle) ++count;
} return (count>numbers.size()/) ? middle : ;
}
};

解法二:
如果有符合条件的数字,则它出现的次数比其他所有数字出现的次数和还要多
在遍历数组时保存两个值:一是数组中一个数字,一是次数。遍历下一个数字时,若它与之前保存的数字相同,则次数加1,否则次数减1;
若次数为0,则保存下一个数字,并将次数置为1。遍历结束后,所保存的数字即为所求。然后再判断它是否符合条件即可。

class Solution {
public: // 如果输入的数组没有超过一半次数的数字,返回false
bool CheckMoreThanHalf(vector<int> numbers, int number)
{
int times = ;
for(int i = ; i < numbers.size(); ++i)
{
if(numbers[i] == number)
{
++times;
}
} bool isMoreThanHalf = true;
if(times * <= numbers.size())
{
isMoreThanHalf = false;
}
return isMoreThanHalf;
} int MoreThanHalfNum_Solution(vector<int> numbers) {
int length = numbers.size();
if(length == )
return ; // 遍历每个元素,并记录次数;若与前一个元素相同,则次数加1,否则次数减1
int result = numbers[];
int times = ;
for(int i = ; i < length; ++i)
{
if(times == )
{
// 更新result的值为当前元素,并置次数为1
result = numbers[i];
times = ;
}
else if(numbers[i] == result)
++times; // 相同则加1
else
--times; // 不同则减1
} // 判断result是否符合条件,即出现次数大于数组长度的一半
if(!CheckMoreThanHalf(numbers, result))
result = ; return result;
}
};

面试题42:连续子数组的最大和

输入一个整形数组,数组里有正数也有负数。数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。要求时间复杂度为O(n)

class Solution {
public:
bool g_InvalidInput = false;
int FindGreatestSumOfSubArray(vector<int> array) {
//为了区分0和无效输入,定义了一个全局变量
if(array.size() <= )
{
g_InvalidInput = true;
return ;
} g_InvalidInput = false; int CurSum = ; // 最小的负数
int GreatestSum = 0x80000000;
//int GreatestSum = 0;
for(int i = ; i < array.size(); ++i)
{
if(CurSum <= )
{
CurSum = array[i];
}
else
{
CurSum += array[i];
}
if(CurSum > GreatestSum)
GreatestSum = CurSum;
}
return GreatestSum;
}
};

面试题53:数字在排序数组中出现的次数

统计一个数字在排序数组中出现的次数。

class Solution {
public:
// 因为data是整数,不是搜索k的两个位置,而是搜索k+0.5和k-0.5
// 这两个数应该插入的位置,然后相减即可 int Search(const vector<int> data, double num)
{
int start = ;
int end = data.size() - ; while(start <= end)
{
int mid = start + (end - start) / ;
if(data[mid] < num)
{
start = mid + ;
}
else if(data[mid] > num)
{
end = mid - ;
}
}
return start;
} int GetNumberOfK(vector<int> data ,int k) {
return Search(data, k + 0.5) - Search(data, k - 0.5);
}
};

面试题53(二):0~n-1中缺失的数字

一个长度为n-1的递增排序数组中的所有数字都是唯一的,并且每个数字都在范围0~n-1之内。
在范围0~n-1之内的所有数字中有且只有一个数字不在该数组中,请找出这个数字

解法一: 时间复杂度为O(n)

int GetMissingNumber(const int *numbers, int length)
{
if(numbers == nullptr || length < )
return -; s1 = (length + ) * length / ;
int sum = ;
for(int i = ; i < length; ++i)
{
sum += numbers[i];
}
return s1 - sum;
}

解法二:

int GetMissingNumber(const int *numbers, int length)
{
if(numbers == nullptr || length < )
return -; int start = ;
int end = length - ;
while(start <= end)
{
int mid = start + (end - start) / ;
if(numbers[mid] != mid)
{
if(mid == || numbers[mid - ] == mid - )
return mid;
end = mid - ;
}
else
start = mid + ;
}
// 如果0-n-1恰好就缺失n-1呢?
// 返回最后一个
if(start = length)
return length; // 无效的输入,比如数组不是按要求排序的
// 或者有数字不在0~n-1范围之内
return -;
}

面试题53(三):数组中数值和下标相等的元素

假设一个单调递增的数组里每个元素都是整数并且是唯一的。请编程实现一个函数,找出数组中任意一个数值等于其下标的元素。例如:在数组{-3, -1, 1, 3, 5},数字3和它的下标相等

// 标准的二分查找法
int GetNumberSameAsIndex(const int* number, int length)
{
if(number == nullptr || length < )
return -; int start = ;
int end = length - ;
while(start <= end)
{
int mid = start + (end - start) / ;
if(number[mid] == mid)
return mid;
else if(number[mid] > mid)
end = mid - ;
else
start = mid + ;
}
return -;
}

剑指offer数组2的更多相关文章

  1. 剑指 Offer —— 数组中重复的数字

    数组中的重复数字 题目描述 牛课网链接 长度为 n 的数组里,所有数字都在 0 到 n-1 的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一 ...

  2. 剑指offer 数组中重复的数

    在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长度为7的数组{ ...

  3. 剑指Offer 数组中只出现一次的数字

    题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字.   思路: 因为有2个数字只出现了一次,而其他的数字都是2次,可以通过异或运算,得到最后这2个只 ...

  4. [剑指OFFER] 数组中的逆序对

    题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数.     分析:利用归并排序的思想,分成2部分,每一部分按照从大到 ...

  5. 剑指offer数组3

    面试题11:旋转数组的最小数字 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1,2}为{1,2 ...

  6. 剑指offer数组1

    面试题3:数组中重复的数字 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例 ...

  7. 剑指offer数组列表

    一.数组 面试题3 : 找出数组中重复的数字 面试题3(二):不修改数组找出重复的数字 面试题4:二维数组的查找 面试题21:调整数组顺序使奇数位于偶数前面 面试题39:数组中出现次数超过一半的数字 ...

  8. 剑指Offer——数组中重复的数字

    题目描述: 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长度 ...

  9. 剑指Offer——数组中只出现一次的数字

    题目描述: 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. 分析: 数组中一共有偶数个数.两个数字只出现过一次. 相同数异或在一起等于0,那么将所有数异或 ...

随机推荐

  1. Python——Pycharm基本设置

    一.,模板(加入中文UTF-8) #!/usr/bin/env python # -*- coding:utf-8 -*- 设置方法:file->settings->Editor-> ...

  2. HDU 2571 命运(简单dp)

    传送门 真是刷越多题,越容易满足.算是一道很简单的DP了.终于可以自己写出来了. 二维矩阵每个点都有一个幸运值,要求从左上走到右下最多能积累多少幸运值. 重点就是左上右下必须都踩到. dp[i][j] ...

  3. springdata 动态查询 是用来查询的 仅提供查询功能

    springdata 动态查询 是用来查询的 仅提供查询功能

  4. python抓取NBA现役球员基本信息数据并进行分析

    链接:http://china.nba.com/playerindex/ 所需获取JSON数据页面链接:http://china.nba.com/static/data/league/playerli ...

  5. [BZOJ 4818] [SDOI 2017] 序列计数

    Description Alice想要得到一个长度为 \(n\) 的序列,序列中的数都是不超过 \(m\) 的正整数,而且这 \(n\) 个数的和是 \(p\) 的倍数. Alice还希望,这 \(n ...

  6. java并发编程实践——王宝令(极客时间)学习笔记

    1.并发 分工:如何高效地拆解任务并分配给线程 同步:线程之间如何协作 互斥:保证同一时刻只允许一个线程访问共享资源 Fork/Join 框架就是一种分工模式,CountDownLatch 就是一种典 ...

  7. Python 面向对象高阶-----metaclass

    Python 面向对象高阶-----metaclass 前言 类也是对象,既然类是对象,那就自然是某个东西的实例化,这个东西就是type 首先看下type是怎么回事 type type最常用的方法就是 ...

  8. 联想的笔记本有隐藏分区 导致无法安装win10 eufi启动 报错:windows无法更新计算机的启动配置。无法安装

    联想的笔记本都带着类似一键还原等的系统恢复软件,这些软件往往是将出厂设置备份在单 独的一个分区,此分区默认为隐藏,在 Windows 的磁盘管理中可以看到.打开磁盘管理器 的方法是右击计算机——管理, ...

  9. URL传递中文参数乱码问题

    web项目开发中,经常遇到中文参数乱码问题,而且有时候明明测试服务器上好用,换个正式环境就不用的情况也经常出现,今天做一个记录,防止自己以后忘记 1.地址栏url请求带中文参数 这类

  10. python格式化输出的几种方式

    第一种  字符串拼接  就不写了 下面的是 第二 第三 第四种 name = input("name:") age = int(input("age:")) p ...