当前位置: 首页 > news >正文

【笔试强训编程题】Day3.(字符串中找出连续最长的数字串 69385)和(数组中出现次数超过一半的数字 23271)

作者简介:大家好,我是未央;

博客首页:未央.303

系列专栏:笔试强训编程题

每日一句:人的一生,可以有所作为的时机只有一次,那就是现在!!!!

文章目录

​编辑 

前言

一、字符串中找出连续最长的数字串 69385

题目描述

题目解析

代码实现

总结


 

前言

一、字符串中找出连续最长的数字串 69385

题目描述

给一个长度为 n 的数组,数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如:输入一个长度为9的数组[1,2,3,2,2,2,5,4,2]。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。

输入描述:

保证数组输入非空,且保证有解

示例:



题目解析:

 解题思路:

看到本题后主要有两种思路:
思路一(常见简单的)
  1. 首先对我们的数组进行排序操作(不限升降关系);
  2. 找到中间的字母X;
  3. 然后对这个数组进行遍历操作;(看一下这个数组出现了多少次)

思路二(众数消去思想)

总体思路描述:

如果两个数不相等,就消去这两个数;

最坏的情况下,每次会消去一个众数和非众数;

那么如果存在众数的话,最后留下的数一定是众数;但是如果不纯在众数,则一定不是;

(所以这个地方依然要通过遍历数组来判断最后一个数是否为众数)


代码实现

思路一:


思路二:


总结

 

http://www.lryc.cn/news/91429.html

相关文章:

  • 学懂缓存雪崩,缓存击穿,缓存穿透仅需一篇,基于Redis讲解
  • Android 12.0SystemUI 状态栏下拉和通知栏始终居中
  • 面向过程编程和面向对象编程的区别
  • 2023年数学与人工智能国际会议——火热征稿中~
  • 格式化数字的实用命令:numfmt
  • 传统的交叉熵函数如何通过平滑处理可以适用于多标签分类任务
  • 关于Netty的一些问题
  • Java - ThreadLocal数据存储和传递方式的演变之路
  • vuex三问
  • Selenium自动化测试(基于Java)
  • 【网页布局形式----浮动】
  • 人力资源管理的本质
  • [NOIP2015 提高组] 运输计划
  • 【GreendDao 】RxQuery根据指定条件查询,完成后处理UI逻辑
  • 【C++】unordered_set 和 unordered_map 使用 | 封装
  • C++环形缓冲区设计与实现:从原理到应用的全方位解析
  • 阿里云服务器部署flask简单方法
  • 【JavaSE】Java基础语法(二十三):递归与数组的高级操作
  • HUSTOJ使用指南
  • java基础学习
  • Linux——进程优先级
  • 音频设备初始化与输出:QT与SDL策略模式的实现
  • Linux 手动部署 SpringBoot 项目
  • 华为OD机试真题B卷 Java 实现【内存资源分配】
  • 深入理解ChatGPT插件:competitorppcads、seoanalysis和kraftful
  • 通过源码编译安装LAMP平台的搭建
  • mac os 安装rz/sz
  • Redis源码(1) 建立监听服务和开启事件循环
  • c++基础概念,const与指针、引用的关系,auto,decltype关键字能干啥总得了解吧。总得按照需求自定义创建实体类,自己编写头文件吧
  • 【数据结构】---几分钟简单几步学会手撕链式二叉树(下)