剑指offer二刷——数组专题——数组中出现次数超过一半的数字
题目描述
我的理解
找到数组中超过一半的数,即众数。设置一个变量tmp保存当前假设认为是众数的数,设置cnt保存tmp未被抵消的次数。遍历数组,若当前数字不是tmp,则cnt--;若当前数字是tmp,则cnt++;若cnt=0,则tmp换成下一个数字。
这是时间复杂度为O(n),空间复杂度O(1)的最优解。
# -*- coding:utf-8 -*-
class Solution:
def MoreThanHalfNum_Solution(self, numbers):
# write code here
tmp = -1
cnt = 0
for i in range(len(numbers)):
if cnt==0:
tmp = numbers[i]
cnt+=1
else:
if numbers[i]==tmp:
cnt+=1
else:
cnt-=1
sum=0
for k in numbers:
if k==tmp: sum+=1
if sum >= len(numbers)/2+1:
return tmp
else:return 0
解法二 排序
将数组排序,然后找到众数
时间复杂度O(nlogn)
空间复杂度O(1)
解法三 哈希
为数组建立一个字典,遍历数组,得出每个数字出现的次数。
时间复杂度O(n)
空间复杂度O(n)
剑指offer二刷——数组专题——数组中出现次数超过一半的数字的更多相关文章
- 剑指offer二刷(精刷)
		
剑指 Offer 03. 数组中重复的数字 题目描述 在一个长度为 n 的数组里的所有数字都在 0 到 n-1 的范围内.数组中某些数字是重复的,但不知道有几个数字是重复的,也不知道每个数字重复几次. ...
 - 剑指offer二刷——数组专题——数组中重复的数字
		
题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长度为 ...
 - 剑指offer二刷——数组专题——数字在升序数组中出现的次数
		
题目描述 统计一个数字在升序数组中出现的次数. 我的想法 完整的解法我只想到了遍历数组然后依次统计,但这是不聪明的解法,而且没有利用上"升序数组"的这个条件. 题目标签有提醒可以用 ...
 - 剑指offer二刷——数组专题——斐波那契数列
		
题目描述 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0,第1项是1). n<=39 我的想法 斐波那契数列定义:F(0)=0,F(1)=1, ...
 - 剑指offer二刷——数组专题——构建乘积数组
		
构建乘积数组 题目描述 给定一个数组A[0,1,...,n-1],请构建一个数组B[0,1,...,n-1],其中B中的元素B[i]=A[0]*A[1]*...*A[i-1]*A[i+1]*...*A ...
 - 剑指offer二十八之数组中出现次数超过一半的数字
		
一.题目 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2. ...
 - 剑指Offer(二十八):数组中出现次数超过一半的数字
		
剑指Offer(二十八):数组中出现次数超过一半的数字 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn. ...
 - 剑指 Offer 53 - I. 在排序数组中查找数字 I + 二分法
		
剑指 Offer 53 - I. 在排序数组中查找数字 I Offer_53_1 题目描述 方法一:使用HashMap package com.walegarrett.offer; /** * @Au ...
 - 剑指 Offer 39. 数组中出现次数超过一半的数字 + 摩尔投票法
		
剑指 Offer 39. 数组中出现次数超过一半的数字 Offer_39 题目描述 方法一:使用map存储数字出现的次数 public class Offer_39 { public int majo ...
 
随机推荐
- Failed connect to mirrors.cloud.aliyuncs.com:80
			
在yum insatall 安装是报错 Failed connect to mirrors.cloud.aliyuncs.com:80; Connection refused 解决方法: cd /et ...
 - lua调用dll demo
			
使用的是lua5.3 DllMain.cpp 1 //生成的dll 是 lua_add53.dll 2 //luaopen_lua_add 3 extern "C" { 4 #in ...
 - linux c 线程间同步(通信)的几种方法--互斥锁,条件变量,信号量,读写锁
			
Linux下提供了多种方式来处理线程同步,最常用的是互斥锁.条件变量.信号量和读写锁. 下面是思维导图: 一.互斥锁(mutex) 锁机制是同一时刻只允许一个线程执行一个关键部分的代码. 1 . ...
 - ip rule 策略路由
			
1. 工具安装 yum install iproute 查看工具是否安装 ip -V 2. ip rule 和 ip route ip命令中和策略路由相关的OBJECT有 rule 和 route. ...
 - 调用外部接口支持https请求
			
1,创建RestTemplateConfig.java文件,内容如下: package com.htsec.monitor.internet.config;import com.htsec.monit ...
 - springboot做邮件发送功能时报错No qualifying bean of type 'org.springframework.mail.javamail.JavaMailSender' available:的问题解决方案
			
1.检查application.yml中的配置是否正确 spring.mail.host=smtp.xxx.comspring.mail.username=xxx@xxx.comspring.mail ...
 - Python_Tips
			
Python绝对路径与相对路径读写文件[上级目录: os.path.dirname(os.getcwd())] # coding:utf8 ''' 知识点:Python读写文件时候的相对路径与绝对路径 ...
 - phpstorm换行符设置LF
			
git执行命令行 git config --global core.autocrlf true
 - SHEIN:Java开发面经
			
SHEIN面经 我觉得除技术外,自信是一个非常关键的点. 一面 自我介绍: 谈谈实习经历: 讲讲你实习的收获: 如何设计规范的接口?(简历上有写,所以问到) 当你需要修改两个月前的代码时,如何去整理以 ...
 - idea中运行tomcat不能访问8080主页问题
			
问题 初次使用IntelliJ IDEA,但今天在运行项目启动Tomcat后,发现无法访问Tomcat首页,出现404错误:输入http://localhost:8080时无法访问Tomcat首页,但 ...