Question:数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字

package com.study.zhipengs.test;

import java.util.Arrays;
import java.util.HashMap;
import java.util.Map; /**
* 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。
* 例如输入一个长度为9的数组{1, 2, 3, 2, 2, 2, 5, 4,
* 2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2.
*
* 所有数字的个数均没有超过数组长度的一半,则返回-1
*
* @author zhipegs
*
*/
public class Test { public static void main(String[] args) {
int[] numbers = { 1, 2, 2, 5, 6, 2, 5, 2, 2};
System.out.println("number: " + mapSolve(numbers));
System.out.println("number: " + sortSolve(numbers));
} /**
* 先排序---排序后统计每个数字出现的次数,出现次数超过数组长度一半的那个一定出现在中间
* @param numbers
* @return int
*/
private static int sortSolve(int[] numbers) {
Arrays.sort(numbers);
int count = 0;
int len = numbers.length;
int pos = (int) Math.rint((double)len/2.0);
int midValue = numbers[pos];
for(int i=0;i<len;i++) {
if(numbers[i] == midValue) {
count ++;
if(count > pos) {
return midValue;
}
}
}
return -1;
} /**
* 不排序--相同数字存储到Map的key中,个数在value中递增计算
* @param numbers
* @return int
*/
private static int mapSolve(int[] numbers) {
int len = numbers.length;
int pos = (int) Math.rint((double)len/2.0);
Map<String,MyInteger> map = new HashMap<String,MyInteger>();
MyInteger mi;
for(int i=0;i<numbers.length;i++) {
String key = numbers[i]+"";
mi = map.get(key);
if(mi != null) {
int value = mi.get()+1;
mi.set(value);
map.put(key, mi);
if(value > pos) {
return numbers[i];
}
continue;
}
mi = new MyInteger();
mi.set(1);
map.put(key, mi);
}
return -1;
} } /**
* 自定义MyInteger
*/
class MyInteger {
private int value; public void set(int value) {
this.value = value;
} public int get() {
return this.value;
} @Override
public String toString() {
return "MyInteger [value=" + value + "]";
}
}

总结:多看书和博客,从别人的代码分享中理解思路,越思越明~~

找出整数数组中出现次数超过数组长度一半的元素(Java)的更多相关文章

  1. 《剑指offer》数组中出现次数超过数组长度一半的数字

    题目: 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2.如 ...

  2. 【剑指offer】数组中出现次数超过数组长度一半的数字,C++实现

    原创博文,转载请注明出处! # 题目 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过 ...

  3. [PY3]——找出一个序列中出现次数最多的元素/collections.Counter 类的用法

    问题 怎样找出一个序列中出现次数最多的元素呢? 解决方案 collections.Counter 类就是专门为这类问题而设计的, 它甚至有一个有用的 most_common() 方法直接给了你答案 c ...

  4. 28.数组中出现次数超过长度一半的数字(python)

    题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2. ...

  5. LeetCode 5126. 有序数组中出现次数超过25%的元素 Element Appearing More Than 25% In Sorted Array

    地址 https://leetcode-cn.com/contest/biweekly-contest-15/problems/element-appearing-more-than-25-in-so ...

  6. 如何在O(n)的时间复杂度内找出数组中出现次数超过了一半的数

    方法一:每次取出两个不同的数,剩下的数字中重复出现次数超过一半的数字肯定,将规模缩小化.如果每次删除两个不同的数,这里当然不是真的把它们踢出数组,而是对于候选数来说,出现次数减一,对于其他数来说,循环 ...

  7. 229. Majority Element II -- 找出数组中出现次数超过 ⌊ n/3 ⌋ 次的数

    Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times. The algorit ...

  8. python 找出一篇文章中出现次数最多的10个单词

    #!/usr/bin/python #Filename: readlinepy.py import sys,re urldir=r"C:\python27\a.txt" disto ...

  9. 找出数组中出现次数超过一半的数,现在有一个数组,已知一个数出现的次数超过了一半,请用O(n)的复杂度的算法找出这个数

    找出数组中出现次数超过一半的数,现在有一个数组,已知一个数出现的次数超过了一半,请用O(n)的复杂度的算法找出这个数 #include<iostream>using namespace s ...

随机推荐

  1. 洛谷P1901发射站

    题目 一道单调栈裸题,主要是用单调栈维护单调性,和单调队列都可以在\(O(n)\)的时间内得出单调最大值或最小值,要比堆要快. 这个题可以用h来当做单调栈的使用对象,即用单调栈来维护高度,高度是越在栈 ...

  2. mysql创建账号、授权、数据导出、导入

    1.账号创建及授权 grant all privileges on *.* to 'yangxin'@'%' identified by 'yangxin123456' with grant opti ...

  3. [java][JEECG] Maven settings.xml JEECG项目初始化 RouYi settings.xml配置

    好吧一下是经验之谈,原本这些坑不应该躺的,从头看手册完全可以避免这些. 懒得整理了,看懂了就看,看不懂自己琢磨JEECG的帮助文档去,不过嘛我喜欢用Intelij IDEA,他里面都是别的IDE,不喜 ...

  4. Pytest权威教程08-使用tmp目录和文件

    目录 使用tmp目录和文件 tmp_path Fixture方法 tmp_path_factory Fixture方法 tmpdir Fixture方法 tmpdir_factory Fixture方 ...

  5. Nginx介绍和使用

    Nginx介绍和使用 一.介绍 Nginx是一个十分轻量级并且高性能HTTP和反向代理服务器,同样也是一个IMAP/POP3/SMTP代理服务器. 二.特性 HTTP服务器 反向代理服务器 简单的负载 ...

  6. 元素在当前窗口可视的区域---Element.scrollIntoView()

    element.scrollIntoView(); // 等同于element.scrollIntoView(true) element.scrollIntoView(alignToTop); // ...

  7. ubuntu之路——day9.1 深度学习超参数的调优

    参数重要性: 第一阶:α即learning rate 第二阶:momentum中的β,hidden units的数量,mini-batch的大小 第三阶:hidden layers的数量,learni ...

  8. 聊聊SSH框架

    目录 前期准备工作 jrebel(热加载,后台会自动帮忙部署项目) lombok(根据字段,自动生成对应的set和get方法) log4j(日志打印) 所需jar包 log4j2.xml log4j. ...

  9. Mysql sql_mode设置 timestamp default 0000-00-00 00:00:00 创建表失败处理

    往数据库里创建新表的时候报错: [Err] 1067 - Invalid default value for 'updateTime' DROP TABLE IF EXISTS `passwd_res ...

  10. 【maven】在pom.xml中引入对json-lib的依赖dependency

    <dependency> <groupId>net.sf.json-lib</groupId> <artifactId>json-lib</art ...