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

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

方法1:Hash链表

方法2:使用两个变量A和B,其中A存储某个数组中的数,B用来计数。开始时将B初始化为0。

遍历数组,

如果B=0,则令A等于当前数,令B等于1;

如果当前数与A相同,则B=B+1;

如果当前数与A不同,则令B=B-1。

遍历结束时,A中的数就是要找的数。

这个算法的时间复杂度是O(n),空间复杂度为O(1)。

c语言描述:

 

int main()
{int i,A,B;int a[10]={1,2,3,1,2,1,1,6,1,1};A=a[5];B=0;
  for(i=0; i<10; i++)
  if(B=0){A = a[i];B =1;}elseif( A==a[i])B++;elseif(A!=a[i])B--;printf("%d", A);getchar();
  return 0;
}

 

转载于:https://www.cnblogs.com/ciangcic/p/3528218.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/461701.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

中断——S5PV210的中断案例

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 参考博客 s5pv210——中断 - biaohc - 博客园 S5PV210的中断体系简介_天糊土的博客-CSDN博客 一、S5PV210的中断流程 第一部分是我们为中断响应而做的预备工作。 1、初始化中断控制器 比如先关闭所…

oracle 如何查看当前用户的表空间名称

如何查询当前用户的表空间名称&#xff1f;因为oracle建立索引&#xff0c;需要知道当前用户的表空间&#xff0c;查找了一下资料 --查询语法--select default_tablespace from dba_users where username登录用户如&#xff0c;我的登录用户是TMS21,那么查询语法是 /* 查看用户…

powerdesigner15(pd)+Oracle 11g 开发小问题

这几天使用powerdesigner15&#xff08;pd&#xff09;Oracle 11g 做数据库&#xff0c;中途遇到几个问题。 虽然很快都解决了但是还是记一下吧&#xff0c;提醒自己&#xff0c;也也遇到同样问题的人以帮助。 1、问题一 在设计的时候我的文本字段设计的是 nvarchar 长度是40…

PHP多种形式发送邮件

1. 使用 mail() 函数 没什么好讲的&#xff0c;就是使用系统自带的smtp系统来发送&#xff0c;一般是使用sendmail来发。这个按照各个系统不同而定。使用参考手册。 2. 使用管道的形式 昨天刚测试成功&#xff0c;使用本地的qmail来发送邮件。 1 /* 使用qmail发送邮件函数 */ …

按键——S5PV210的按键简介(轮询方式+中断方式)

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 参考博客 s5pv210——按键 - biaohc - 博客园 一、按键的简介 1、按键的物理特性 按钮没有被按下时&#xff0c;内部是断开的。按钮被按下时&#xff0c;内部保持接通状态&#xff1b;放手后由于弹…

Platform Invoke and Marshaling Data: [1/3]

Moved to http://blog.tangcs.com/2008/06/15/pinvoke-and-marshaling-data-1/转载于:https://www.cnblogs.com/WarrenTang/archive/2008/06/15/1222750.html

Windows开发的内功和招式

Windows开发的内功和招式 最近一个月笔者休了大约两周的假期&#xff0c;期间没有学习新的开发技术&#xff0c;也没有去游山玩水&#xff0c;而是对自己的知识结构和Windows开发本身进行了一个深入的思考&#xff0c;收获颇多&#xff0c;在这里希望和大家共同分享一下。 如果…

HAproxy + Keepalive实现LDAP代理服务

HAproxy Keepalive实现LDAP代理服务因为公司的各种高自研发的系统非常多&#xff0c;这些系统又全部是在使用LDAP做认证&#xff0c;目前我们有几台DC控制器来分担这些ldap请求&#xff0c;用户通过访问ldap.xxxx.com这个域名来连接ldap服务器&#xff0c;我们通过DNS轮询的方…

中断——S5PV210的中断源

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 前言 s5pv210中因为支持的中断源很多&#xff0c;因此直接设计了4个中断寄存器&#xff0c;每个32位&#xff0c;每位对应一个中断源。理论上210最多支持128个中断&#xff0c;实际支持不足128个&a…

读书笔记(六)--成交

读书笔记--第6篇--《成交》1.在IT企业&#xff0c;陌生人很容易一眼就能分辨出谁做销售&#xff0c;谁做技术&#xff0c;谁做管理。 冲着陌生人微笑言语客气的一般是销售&#xff0c;一脸漠然甚至有些高傲的是技术&#xff0c;用探寻的眼光打量你的往往就是管理了。 2.在IT企业…

mysql 按照两个字段之和进行排序

SELECT *,zan_numfake_zan_num show_zan FROM tf_news order by show_zan desc TP实现 $news M(news); $result_list $news->where($where)->limit($start . , . $step)->field(*,zan_numfake_zan_num show_num)->order($order)->select(); 转载于:https://ww…

排序与查找

为什么80%的码农都做不了架构师&#xff1f;>>> sort.h #ifndef SORT_H_INCLUDED #define SORT_H_INCLUDEDvoid bubble_sort(int a[], int len);void select_sort(int a[], int len);#endif // SORT_H_INCLUDED sort.cpp #include "sort.h"void bubble_s…

LCD——S5PV210的LCD的理论与操作

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 参考博客 s5pv210 LCD编程原理 - biaohc - 博客园 一、关于LCD的简介 1、LCD简介 &#xff08;1&#xff09;什么是LCD LCD&#xff08;Liquid Crystal Display&#xff09;俗称液晶。液晶是一种材…

Java学习总结之第十一章 Java集合

一、总结 1. 所有Java集合类都位于java.util包中&#xff0c;与Java数组不同&#xff0c;Java集合中不能存放基本数据类型&#xff0c;只能存放对象的引用。 2. Set、List、Map统称为Java集合。 3. 在将对象存储到集合类中时&#xff0c;为加快存储速度&#xff0c;要求被在座对…

text/html与text/plain的区别

1.ContentType 属性指定响应的 HTTP 内容类型。如果未指定 ContentType&#xff0c;默认为 text/HTML。 2.text/html按网页形式解析报文体 text/plain为无格式文本&#xff0c;即直接将报文体输出 3.当输出的报文体中含有html结构型标签如head ,body,html等时&#xff0c;浏览器…

分析三星提供的sd_fusing文件夹(用来制作SD卡启动镜像)

以下内容源于网络资源的学习与整理&#xff0c;如有其侵权请告知删除。 参考博客 uboot分析&#xff1a;SD卡镜像制作脚本分析 - 走看看 如何烧写u-boot到SD卡 S5PV210 Uboot开发与移植01&#xff1a;Uboot概述&#xff08;推荐&#xff09; 一、sd_fusing文件夹简介 1、文件…

Linux系统管理----LVM逻辑卷和磁盘配额作业习题

1&#xff0e;为主机增加80G SCSI 接口硬盘 2&#xff0e;划分三个各20G的主分区 [rootlocalhost chen]# fdisk /dev/sdb 命令(输入 m 获取帮助)&#xff1a;n Partition type: p primary (0 primary, 0 extended, 4 free) e extended Select (default p): Using default r…

外存——S5PV210的外部存储器(nandflash与inand的介绍)

以下内容源于朱有鹏嵌入式课程的学习与整理&#xff0c;如有侵权请告知删除。 参考内容 关于iNand ,oneNand,moviNAND的区别——大家一起来扫盲 - 嵌入式系统 总结 本文首先介绍了目前主流的外存设备有哪些。 然后介绍了NandFlash芯片的接口、结构、常见操作&#xff0c;以及…

软件定义的数据中心已经来临

VMware和微软提供了软件定义的数据中心的解决方案。在软件定义的数据中心中&#xff0c;所有的资源——包括计算、存储、可用性、网络和安全等——都实现了虚拟化和自动化。本文主要关注的是其中新加入的特性&#xff1a;虚拟化网络与安全。 为了提供一个完全自动化的数据中心&…