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

长沙网站排名公司百度一下你就知道了

长沙网站排名公司,百度一下你就知道了,四川党的建设网站怎样投稿,wordpress download manager题目: 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。 你可以假设数组是非空的,并且给定的数组总是存在多数元素。 示例: 输入: [1, 2, 3, 2, 2, 2, 5, 4, 2] 输出: 2 思考: 方法一:投…

题目:

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

你可以假设数组是非空的,并且给定的数组总是存在多数元素。

示例:

输入: [1, 2, 3, 2, 2, 2, 5, 4, 2]
输出: 2

思考:

  • 方法一:投机取巧

  • 将数组排序,出现次数超过一半的数字肯定在数组中间的那个位置

题解:

class Solution {public int majorityElement(int[] nums) {Arrays.sort(nums);return nums[nums.length / 2];}
}

思考:

  • 方法二:哈希表辅助

  • 使用一个 map,key 存数组中的数字,val 存出现的次数

  • 当有数字出现次数超过数组长度一半时,直接返回

题解:

class Solution {public int majorityElement(int[] nums) {Map<Integer,Integer> map = new HashMap<>();for(int num : nums){map.put(num,map.getOrDefault(num,0)+1);if(map.get(num)> nums.length>>1) return num;}return 0;}
}

思考:

  • 方法三,摩尔投票法

  • 众数和非众数投票,初始票数为 0,为 0 时假设当前数字为众数

  • 遍历数组,是众数 +1,不是众数 -1,为 0 就接着继续重新来

  • 最后得到众数

题解:

class Solution {public int majorityElement(int[] nums) {int vote = 0;int x = 0;for (int i = 0; i < nums.length; i++) {if (vote == 0) x = nums[i];if (x == nums[i]) vote++;else vote--;}return x;}
}
http://www.mmbaike.com/news/93954.html

相关文章:

  • 大连模板网站制作哪家好百度商务合作联系
  • 网站开发的资料设备百度链接收录
  • 代理公司英文湖南seo优化
  • 聊城专业做网站的公司网站seo设置是什么
  • 北京企业网站建设方中国职业培训在线官方网站
  • 网站的栏目是什么河南推广网站的公司
  • 怎样建设淘宝网站郑州seo网站有优化
  • 网站建设战略伙伴学生班级优化大师
  • 做二手钢结构网站发布外链
  • 优化网站推广前端seo是什么意思
  • 塘坑网站建设南昌seo排名外包
  • 红木家具网站建设总体规划游戏推广员到底犯不犯法
  • 做的物流网站市场调研的四个步骤
  • 网站设计模板网站在线优化检测
  • net后缀的可以做网站吗百度一下首页网址
  • 网站的好处域名买卖交易平台
  • 国内做香港视频网站有哪些互联网平台公司有哪些
  • 做网站需要许可证吗国外广告联盟平台
  • 上海网站建设网页制网站网页设计
  • 深圳企业网站建设服务哪家公司好seo外贸公司推广
  • 网站外链接如何做最好的免费信息发布平台
  • 那里有专做粮食的网站甘肃seo技术
  • 做网站必须先买域名吗网站宣传文案
  • 有特色的企业网站网络优化公司哪家好
  • 网站建设计划方案大亚湾发布
  • 平面设计资源网站设计网站推荐
  • app网站开发定制百度搜索引擎优化方案
  • 邵阳网站建设公司杭州网站优化搜索
  • 建设银行网银网站无法访问百度seo排名优化软件分类
  • 重庆万州网站建设哪家好百度搜索推广和信息流推广