剑指OFFER之数组中出现次数超过一半的数字(九度OJ1370)
题目描述:
-
数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。
- 输入:
-
每个测试案例包括2行:
第一行输入一个整数n(1<=n<=100000),表示数组中元素的个数。
第二行输入n个整数,表示数组中的每个元素,这n个整数的范围是[1,1000000000]。
- 输出:
-
对应每个测试案例,输出出现的次数超过数组长度的一半的数,如果没有输出-1。
- 样例输入:
- 样例输出:
解题思路:
有两种思路。先说在这道题目上能成功的:
我们首先对数组进行排序,因为要找出数目超过一半的数,因此,如果存在,那么这个数组的中间值肯定是这个数。比如
1 2 2 2 1 或者 1 1 2 2 2 或者 2 2 2 3 3,中间的肯定是我们要找的数。
而如果不存在,那么进行一次O(n)的扫描即可。因此我们的算法时间复杂度为快排+一次遍历,O(nlogn)+O(n)。
快排的代码如下:
void Qsort(int begin,int end){
int middle;
if(begin < end){
middle = Patition(begin,end);
Qsort(begin,middle -);
Qsort(middle+,end);
}
}
int Patition(int begin,int end){
int middle = gArr[begin];
while(begin < end){
while(begin < end && gArr[end] >= middle)
end--;
swap(begin,end);
while(begin < end && gArr[begin] <= middle)
begin++;
swap(begin,end);
}
return begin;
}
void swap(int begin,int end){
int tmp = gArr[end];
gArr[end] = gArr[begin];
gArr[begin] = tmp;
}
全部代码:
#include <stdio.h>
#include <stdlib.h>
#define MAXSIZE 100001
int gArr[MAXSIZE] = {};
void Qsort(int begin,int end);
void swap(int begin,int end);
int Patition(int begin,int end);
int main(){
int n,i,middle,count;
while(scanf("%d",&n)!=EOF && n> && n <= ){
for(i=;i<n;i++){
scanf("%d",&gArr[i]);
}
Qsort(,n-);
middle = gArr[n/];
count = ;
for(i=;i<n;i++){
if(middle == gArr[i])
count++;
}
if(count > n/)
printf("%d\n",middle);
else
printf("-1\n");
}
}
void Qsort(int begin,int end){
int middle;
if(begin < end){
middle = Patition(begin,end); Qsort(begin,middle -);
Qsort(middle+,end);
}
}
int Patition(int begin,int end){
int middle = gArr[begin];
while(begin < end){
while(begin < end && gArr[end] >= middle)
end--;
swap(begin,end); while(begin < end && gArr[begin] <= middle)
begin++;
swap(begin,end);
}
return begin;
}
void swap(int begin,int end){
int tmp = gArr[end];
gArr[end] = gArr[begin];
gArr[begin] = tmp;
} /**************************************************************
Problem: 1370
User: xhalo
Language: C
Result: Accepted
Time:800 ms
Memory:1304 kb
****************************************************************/
另外一种思路
我们对每个元素进行统计。但是在记录统计时,有个麻烦处,就是如何从记录数组中查找到我们要记录的元素。下面的代码在数据量很大,我猜测是100000个不重复的点,因此进行遍历时超时了。不过在小数据量时,还是可以的:
#include <stdio.h>
#include <stdlib.h>
#define MAXSIZE 100000
typedef struct flag{
int data;
int counter;
}Flag;
typedef struct fArr{
struct flag arr[MAXSIZE];
}FArr;
int gArr[MAXSIZE] = {};
int gnum;
int main(){
int n,i,max,maxNum;
while(scanf("%d",&n)!=EOF && n> && n <= ){
FArr *a = (FArr *)malloc(sizeof(FArr));
gnum = ;
max = -;
maxNum = -;
for(i=;i<n;i++){
scanf("%d",&gArr[i]);
}
for(i=;i<n;i++){
int j = ;
while(j<gnum){
if(a->arr[j].data == gArr[i])
break;
j++;
}
if(gnum != && j != gnum){
a->arr[j].counter++;
}else{
a->arr[gnum].data = gArr[i];
a->arr[gnum++].counter = ;
}
}
for(i=;i<gnum;i++){
if(max < a->arr[i].counter){
max = a->arr[i].counter;
maxNum = a->arr[i].data;
}
}
if(max > n/)
printf("%d\n",maxNum);
else
printf("-1\n");
}
}
/**************************************************************
Problem: 1370
User: xhalo
Language: C
Result: Time Limit Exceed
****************************************************************/
剑指OFFER之数组中出现次数超过一半的数字(九度OJ1370)的更多相关文章
- 剑指Offer:数组中出现次数超过一半的数字【39】
剑指Offer:数组中出现次数超过一半的数字[39] 题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如,输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于这 ...
- 剑指 Offer 39. 数组中出现次数超过一半的数字 + 摩尔投票法
剑指 Offer 39. 数组中出现次数超过一半的数字 Offer_39 题目描述 方法一:使用map存储数字出现的次数 public class Offer_39 { public int majo ...
- 剑指 Offer 39. 数组中出现次数超过一半的数字
剑指 Offer 39. 数组中出现次数超过一半的数字 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 你可以假设数组是非空的,并且给定的数组总是存在多数元素. 示例 1: 输入: [ ...
- 力扣 - 剑指 Offer 39. 数组中出现次数超过一半的数字
题目 剑指 Offer 39. 数组中出现次数超过一半的数字 思路1(排序) 因为题目说一定会存在超过数组长度一半的一个数字,所以我们将数组排序后,位于length/2位置的一定是众数 代码 clas ...
- 【剑指Offer】数组中出现次数超过一半的数字 解题报告(Python)
[剑指Offer]数组中出现次数超过一半的数字 解题报告(Python) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-inter ...
- 【Java】 剑指offer(39) 数组中出现次数超过一半的数字
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如 ...
- Go语言实现:【剑指offer】数组中出现次数超过一半的数字
该题目来源于牛客网<剑指offer>专题. 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组 ...
- 剑指Offer 28. 数组中出现次数超过一半的数字 (数组)
题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2. ...
- 《剑指offer》-数组中出现次数超过一半的数字
/* 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2.如果 ...
随机推荐
- python学习笔记七--数据操作符的优先级
一.混合表达式哪个部分先计算: 1. 取决于操作符的优先级,不同操作符的优先级是不一样的,例如‘*’的优先级高于‘+’ 2. 上节的表格里越靠后,优先级越高. 3 . 同一表达式的相同操作符是按从左到 ...
- Dreamweaver CS6破解教程[序列号+破解补丁]
Dreamweaver CS6破解教程[序列号+破解补丁] Adobe Dreamweaver CS6中文简体版下载地址:Dreamweaver CS6中文简体版下载[带破解] 破解之前的准备 1 ...
- 【HDOJ】3473 Minimum Sum
划分树解.主席树解MLE. /* 3473 */ #include <iostream> #include <sstream> #include <string> ...
- poj 3026 Borg Maze (最小生成树+bfs)
有几个错误,调试了几个小时,样例过后 1Y. 题目:http://poj.org/problem?id=3026 题意:就是让求A们和S的最小生成树 先用bfs找每两点的距离,再建树.没剪枝 63MS ...
- 各种好用的工具之一 ---- PNGGauntlet
1.PNGGauntlet实际上是一个图形前端,压缩图像的过程中使用的是PNGOUT, OptiPNG, 和DeflOpt这三款软件. 软件官网:http://pnggauntlet.com/ 可自行 ...
- 自定义web浏览器(五)
万维网(Web)服务的客户端浏览程序.可向万维网(Web)服务器发送各种请求,并对从服务器发来的超文本信息和各种 多媒体数据格式进行解释.显示和播放--------百度百科对浏览器给出这样的解释.
- Asp.net MVC 4 异步方法
今天我们来看一下,同样功能在 Asp.net MVC 4 下的实现,基于.net framework 4.5 下的async支持,让我们的代码更加简单,看下面片断代码名叫Index的Action方法: ...
- dephi WaitForMultipleObjects 用法
在Delphi中WaitForMultipleObjects的使用 procedure ThreadTest;stdcall; var Handles:TWOHandleArray; //Hand ...
- 用pip爽久了,竟然完了easy install安装过程了
新换了mac,装python环境时才发现,一直用pip,反而忘了easy_install的安装方法了.这里记录一下: 1.下载ez_install.py文件:https://bootstrap.pyp ...
- Struts2 Spring Hibernate Ajax Java总结(实时更新)
1. 在form表单的onload属性里的方法无法执行? 若忘记了在<%=request.getSession().getAttribute("userName")%> ...