给定一个长度为N的数组,找出出现次数大于n/2,n/3的数,要求时间复杂度O(n),空间复杂度O(1)
先讨论出现次数大于n/2的数字,如果这样的数字存在,那么这个数出现的次数大于其他数出现的次数的总和。
在数组A中,我们定义两个数据集合a1,a2。a1为出现次数大于n/2的数的集合,a2为其余数组成的集合。对于数组
A中元素a、b,假设a不等于b,那么有两种情况,分别为:a属于a1,b属于a2;a属于a2,b属于a2。对于这两种情况,如
果把a、b从数组A中去掉,集合a1的size依旧是大于a2的。按照这个思路,我们有如下代码:
int m;
int count = ;
for (auto num : nums)
{
// 初始的时候为1
if ( == count)
{
m = num;
++count;
}
else
{
// 相等的话我们加一 不相等就同时去掉
if (m == num)
++count;
else
--count;
}
}
那么对于找出次数大于1/3的情况,我们最多存在两个这样的数字n,m。也就是说任一的n或者m与剩下的部分的比例为1:1,这就转化为求次数大于1/2的情况了。代码如下:
int m, n; //最多存在2个出现次数超过 1/3 的元素
int cm, cn; //对应 m 和 n 的统计
for (auto num : nums) {
if (cm == || num == m) {
m = num;
++cm;
}
else if (cn == || num == n) {
n = num;
++cn;
}
else {
--cm;
--cn;
}
}
  if(cm > (cn+cm)/3) cout << m <<endl;
      if(cn > (cn+cm)/3) cout << n << endl;
可以简单的理解为,如果从不超过1/3的那部分数据中去掉一个数字,那么n,m对应的数据集合分别要去掉一个数字,n,m对应的数据集size大于1/3的条件才不会变。
上面有一个假设是有解的,对于无解的情况,还需要额外的遍历一次进行验证。
给定一个长度为N的数组,找出出现次数大于n/2,n/3的数,要求时间复杂度O(n),空间复杂度O(1)的更多相关文章
- 面试题:给定一个长度为N的数组,其中每个元素的取值范围都是1到N。判断数组中是否有重复的数字
		题目:给定一个长度为N的数组,其中每个元素的取值范围都是1到N.判断数组中是否有重复的数字.(原数组不必保留) 方法1.对数组进行排序(快速,堆),然后比较相邻的元素是否相同.时间复杂度为O(nlog ... 
- 给定数组a[1,2,3],用a里面的元素来生成一个长度为5的数组,打印出其排列组合
		给定数组a[1,2,3],用a里面的元素来生成一个长度为5的数组,打印出其排列组合 ruby代码: def all_possible_arr arr, length = 5 ret = [] leng ... 
- 【c语言】数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字
		题目:数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 比如输入一个长度为9的数组{1,2.3.2,2.2.5,4.2}, 因为数组中数字2出现了5次,超过数组的长度的一半,因此输出2 ... 
- 用最小的空间复杂度找出一个长度为n的数组且数据中的元素是[0,n-1]中任一个重复的数据。
		用最小的空间复杂度找出一个长度为n的数组且数据中的元素是[0,n-1]中任一个重复的数据. 比如:[1, 2, 3, 3, 2, 2, 6, 7, 8, 9] 中 2 or 3 分析:这道题目,实现比 ... 
- java—数组乘积输入: 一个长度为n的整数数组input 输出: 一个长度为n的数组result,满足result[i] = input数组中,除了input[i] 之外的所有数的乘积,不用考虑溢出例如 input {2, 3, 4, 5} output: {60, 40, 30, 24}
		/** * 小米关于小米笔试题 数组乘积输入: 一个长度为n的整数数组input 输出: 一个长度为n的数组result,满足result[i] = * input数组中,除了input[i] 之外的 ... 
- 一个简单的算法,定义一个长度为n的数组,随机顺序存储1至n的的全部正整数,不重复。
		前些天看到.net笔试习题集上的一道小题,要求将1至100内的正整数随机填充到一个长度为100的数组,求一个简单的算法. 今天有空写了一下.代码如下,注释比较详细: using System; usi ... 
- 不用循环,、es6创建一个长度为100的数组
		问题描述:在不使用循环的条件下,如何创建一个长度为100的数组,并且数组的每一个元素是该元素的下标? 结果为: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 1 ... 
- 创建一个长度是5的数组,并填充随机数。使用for循环或者while循环,对这个数组实现反转效果
		package day01; import java.util.Random; /** * 首先创建一个长度是5的数组,并填充随机数.使用for循环或者while循环,对这个数组实现反转效果 * @a ... 
- 前端面试题:不使用loop循环,创建一个长度为100的数组,并且每个元素的值等于它的下标,,怎么实现好?
		昨天,看这道题,脑子锈住了,就是没有思路,没看明白是什么意思?⊙﹏⊙|∣今天早上起床,想到需要思考一下这个问题. 当然,我没想明白为什么要这样做?(创建一个长度为100的数组,并且每个元素的值等于它的 ... 
随机推荐
- Oracle 11.2.0.4单实例打补丁
			Oracle 11.2.0.4单实例打PSU,OJVM PSU补丁快速参考 写在前面: · 1.Oracel打每个补丁的操作有时存在差异,所以不管多熟悉,都应该在打任何补丁之前阅读新补 ... 
- github操作
			Github使用 1. 注册  官网:https://github.com/ 搜索项目 以压缩包的的形式下载demo 克隆项目 创建仓库 克隆项目,编写,完成上传,使用https请求,需要输入用户名 ... 
- Linux Shell脚本编程while语句
			Linux Shell脚本编程while语句案例 1,每隔3秒,打印一次系统负载 #!/bin/bash while truedo uptime sleep 3done 2,把监控结果保存 ... 
- Nginx 反向代理功能-动静分离
			Nginx 反向代理功能-动静分离 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 
- nfs—文件转换器
			前端时间,在做一次设备升级时对nfs有了新的认识. nfs一般认为是文件共享服务器,但在实际的工作环境中,业务服务器有诸多限制,需要有加密隔离措施等等,版本升级和功能调试不同于平时的实验环境. 特别好 ... 
- POJ3070 斐波那契数列递推 矩阵快速幂模板题
			题目分析: 对于给出的n,求出斐波那契数列第n项的最后4为数,当n很大的时候,普通的递推会超时,这里介绍用矩阵快速幂解决当递推次数很大时的结果,这里矩阵已经给出,直接计算即可 #include< ... 
- zookeper分布式搭建
			zookeper的安装如下链接 https://www.cnblogs.com/wanerhu/p/11144815.html 
- 学习:API断点
			API的介绍:API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而 ... 
- Scrapy笔记10- 动态配置爬虫
			Scrapy笔记10- 动态配置爬虫 有很多时候我们需要从多个网站爬取所需要的数据,比如我们想爬取多个网站的新闻,将其存储到数据库同一个表中.我们是不是要对每个网站都得去定义一个Spider类呢? 其 ... 
- iptables 表和链的对应关系
			filter表 主要用于对数据包进行过滤,根据具体的规则决定是否放行该数据包(如DROP.ACCEPT.REJECT.LOG).filter 表对应的内核模块为iptable_filter,包含三个规 ... 
