剑指offer-第五章优化时间和空间效率(数组中出现次数超过一半的数字)
题目:输入一个数组,找出一个数字,它在数组中出现的次数超过数组的一半。
题目规定如果可以改变数组中元素的位置。
思路1:如果数组是排序的,那么中间元素的位置不就是次数超过数组一半的元素吗?是的,因此我们可以才用partition来做判断。如果partition的得到的整数index是在数组的中间,那么该元素就是超过数组中一半次数的元素。时间效率为O(n)。
题目规定不可以改变元素的位置
思路2:此时,我们不能对数据进行排序,因此,我们可以考虑到数组中出现次数超过一半的元素比其他所有的元素都出现的次数多,因此我们可以用一个记录数据出现次数的times来记录数组元素出现的次数。如果该元素出现times加一,如果下一个元素不是该元素,times减一。那么最后一个times设置为1的一定是超过数组一半次数的元素。
Java代码:思路1
import java.util.Random; //允许改变数组中元素的位置,找到超过数组一半的元素。
public class HalfOfArrary {
//如果数组是排序的,找超过一半的数,就很好找,因此我们先来一个快排
public int partition(int[] a,int start,int end){
if(a==null)
return-1;
Random rand=new Random();
int index=start+rand.nextInt(end-start);
swrap(a,index,end);
int small=start-1;
for(index=start;index<end;index++){
if(a[index]<a[end]){
small++;
if(small!=index)
swrap(a,small,index);
}
}
small++;
swrap(a,small,end);
return small;
} public void swrap(int[] a, int index, int end) {
int temp=a[index];
a[index]=a[end];
a[end]=temp;
}
//查找超过一半的数,并返回
public int moreThanHalf(int[] a){
if(a==null)
return 0;
int start=0;
int len=a.length;
int middle=len>>1;
int end=len-1;
int index=partition(a,start,end);
while(index!=middle){
if(index>middle)
{
end=index-1;
index=partition(a,start,end);
}
else{
start=index+1;
index=partition(a,start,end);
}
}
int result=a[middle];
if(!(isMoreThanHalf(a,result))){
return 0;
}
return result; }
//判断数组中是否存在,超过一半的数
public boolean isMoreThanHalf(int[] a, int result) {
boolean isMoreHalf=true;
int time=0;
if(a==null)
return false;
for(int i=0;i<a.length;i++){
if(a[i]==result)
time++;
}
int middle=a.length>>1;
if(time>middle)
isMoreHalf=true;
return isMoreHalf; }
public static void main(String[] args){
int[] a={1,1,1,5,3,4,3,1,1,1,1};
HalfOfArrary hoa=new HalfOfArrary();
int result=hoa.moreThanHalf(a);
System.out.println(result+" ");
}
}
Java代码:思路2
//当规定不能改变数组中元素的位置的时候,找到大于数组中一半数的元素
public class MoreThanOfHalf {
public int moreThanHalfOfArray(int[] a){
if(a==null)
return 0;
int times=1;//标记数组中元素次数
int result=a[0];
for(int i=1;i<a.length;i++){
if(times==0){
result=a[i];
times=1;
}
else if(times==result)
times++;
else
times--;
}
if(!(isMoreThanHalf(a,result)))
result=0;
return result;
}
//判断数组中是否存在,超过一半的数
public boolean isMoreThanHalf(int[] a, int result) {
boolean isMoreHalf=true;
int time=0;
if(a==null)
return false;
for(int i=0;i<a.length;i++){
if(a[i]==result)
time++;
}
int middle=a.length>>1;
if(time>middle)
isMoreHalf=true;
return isMoreHalf; }
public static void main(String[] args){
int[] a={1,2,3,3,4,3,4,3,3,3};
MoreThanOfHalf mh=new MoreThanOfHalf();
int result=mh.moreThanHalfOfArray(a);
System.out.println(result+"");
}
}
剑指offer-第五章优化时间和空间效率(数组中出现次数超过一半的数字)的更多相关文章
- 剑指Offer面试题29(java版):数组中出现次数超过一半的数字
题目:数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 比如输入一个长度为9的数组{1,2,3,2.2,2.5,4,2}.因为数字2在数组中出现5次,超过数组长度的一半,因此输出2. 解 ...
- 剑指offer-第五章优化时间和空间效率(从1到n的整数中1出现的次数)
题目:输入一个整数n,从1到n这n个十进制整数中1出现的次数. 思路1:对1到n中的任意一个数i对其进行求余数来判断个位是否为1,然后再求除数,判断十位是否为1.统计出1的个数.然后对1到n用一个循环 ...
- 剑指offer-第五章优化时间和空间效率(数组中的逆序对的总数)
题目:在数组中如果两个数字的前面的数比后面的数大,则称为一对逆序对.输入一个数组求出数组中逆序对的总数. 以空间换时间:思路:借助一个辅助数组,将原来的数组复制到该数组中.然后将该数组分成子数组,然后 ...
- 剑指offer-第五章优化时间和空间效率(把数组排列成最小的数)
题目:输入一个正整数数组,将所有的数,排列起来,组成一个最小的数.
- 剑指offer-第五章优化时间和空间效率(两个链表的第一个公共节点)
思路1:要求的是两个链表的第一个公共节点,首先想到的是用栈来存放两个链表,然后依次从栈中抛出,直到最后一个相同的节点为止.但是要用到两个栈,空间复杂度为O(n): 思路2:从头到尾分别遍历两个链表得到 ...
- 剑指offer-第五章优化时间和空间效率(在字符串中第一次出现切只出现一次的字符)
题目:在字符串中第一次出现切只出现一次的字符 思路:用HashMap来存放对应的char值和该char出现的次数.做一次变量就可以得到第一个只出现一次的字符. Java代码: import java. ...
- 剑指offer-第五章优化时间和空间效率(连续子数组的最大和)
题目:输入一个数组,数组中有正也有负,数组中连续的一个或者连续的多个数字组成一个子数组.求所有的子数组和的最大值.要求时间复杂度为O(n) 思路:我们的最直观的想法就是求出这个数组中的所有的子数组,然 ...
- 剑指offer-第五章优化时间和空间效率(最小的k个数)
题目:输入n个数,输出最小的k个数. 时间复杂度为O(n) 思路1:我们想的到的最直接的思路就是对这个N个数进行排序,然后就可以找到最小的k个了,同样可以用快排partition.但是只要找到前K个最 ...
- 剑指offer第五章
剑指offer第五章 1.数组中出现次数超过一半的数 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组 ...
随机推荐
- Entity FrameWork 配置 之连接字符串隐藏或重用
C/S项目中使用EF,默认回生成app.config文件夹,软件打包安装成功之后就回生成一个对应exe.config.里面会包含配置的一些信息. 这里介绍给大家一种隐藏连接字符串的方式. 代码如下: ...
- pt-osc使用方法
pt-osc实战运用 1.安装pt-osc,解压即可用 安装包在:10.135.2.217:data/online/software/percona-toolkit-3.0.12.tar.gz tar ...
- iOS 开发 申请定位
在iOS8以后,苹果已经强制开发者在请求定位服务时获得用户的授权,此外iOS状态栏中还有指示图标,提示用户当前应用是否正在使用定位服务.另外在iOS8以后,苹果进一步改善了定位服务,让开发者请求定位服 ...
- 搭建 Spring 开发环境
把以下 jar 包加入到工程的 classpath 下: Spring 的配置文件: 一个典型的 Spring 项目需要创建一个或多个 Bean 配置文件, 这些配置文件用于在 Spring IOC ...
- MapReduce数据筛选
需求: 编写MapReduce程序算出高峰时间段(如9-10点)哪张表被访问的最频繁的表,以及这段时间访问这张表最多的用户,以及这个用户访问这张表的总时间开销. 测试数据: TableName(表名) ...
- .NET Framework(CLI,CLS,CTS,CLR,FCL,BCL)
最下层蓝色部分是.NET Framework的基础,也是所有应用软件的基础..NET Framework不是凭空出来的,实际上API,COM+,和一些相关驱动依然是它的基石..NET Framewor ...
- C# word 类库基本属性介绍
using System;using System.Collections.Generic;using System.Text;using Microsoft.Office.Interop.Word; ...
- vim 中的常用编辑
1.将1到3列行首添加‘#’ :1,3s/^/#/g 2.将1到3列行首去除‘#’ :1,3s/^#//g 3.将1到3列中前两列字符去掉 :1,3s/^..//g 4.将1到3列中行末前两个字符去掉 ...
- protobuf与json转换
protobuf对象不能直接使用jsonlib去转,因为protobuf生成的对象的get方法返回的类型有byte[],而只有String类型可以作为json的key,protobuf提供方法进行转换 ...
- JAR_给别人使用
1. http://zhidao.baidu.com/link?url=Ru2tGNV5iRsuRYlEdWzmKDRz88aYqHAqQBQy8sCaHWhjJpaJpbTGibEk-zyxegNJ ...