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

种子汤唯梁朝伟做视频网站职业教育网站平台建设

种子汤唯梁朝伟做视频网站,职业教育网站平台建设,wordpress 新建一个页面,做网站需要什么人员leetcode_169. 多数元素 问题描述 给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。你可以假设数组是非空的,并且给定的数组总是存在多数元素。 示例 1: 输入:nums …

leetcode_169. 多数元素

问题描述

给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。你可以假设数组是非空的,并且给定的数组总是存在多数元素。

示例 1:

输入:nums = [3,2,3]
输出:3

示例 2:

输入:nums = [2,2,1,1,1,2,2]
输出:2

提示:

  • n == nums.length
  • 1 <= n <= 5 * 104
  • -109 <= nums[i] <= 109

**进阶:**尝试设计时间复杂度为 O ( n ) O(n) O(n)、空间复杂度为 O ( 1 ) O(1) O(1)的算法解决此问题。

题解-Boyer-Moore 投票算法

做这到题我们要紧扣两点, res(结果)一定是数组中最多的, 而且比其他任何数都多!!!

牢记上面的话, 然后我们来看算法

如果一场竞选中, 我们有 n n n个候选人, 每个候选人都会有自己的支持者, 对于第 i i i个候选人($ 0<=i<n ) 他们都有 )他们都有 )他们都有arr[i]$个支持者, 在竞选中, 每个支持者可以为自己支持的候选人投支持票, 同样也可以为自己不支持的候选人投反对票(每个人都只能有一个支持的候选人, 且每个人都能投一次票, 无论是支持还是反对). 这时, 有一个天降猛男**“甲”, 支持者超过了 50 % 50\% 50%, 那么请问, 如果其他候选者联合起来给甲"捣乱", 比如某几个候选人串通, 让他们的支持者去给甲**投反对票, 或者把票都投给某一个""以外的候选者, 能不能对竞选结果产生影响呢?

显然不能, 因为甲的支持者是超过 50 % 50\% 50%的, 哪怕就超过一个人也是一样, 甲是 100 % 100\% 100% 会赢的, 无论其他人怎么操作. 就算剩下的所有的候选人支持者都把票投给一个人, 也不会超过.

在上面那个例子里, 就是我们的多数元素, 甲的支持者的数量就是多数元素出现的次数,

为了实现上面的算法, 我们需要维护两个变量, 一个res记录候选的多数元素和它出现的次数count, 一开始count为0, res记录数组的第一个元素, 随后每当遇到一个与当前res相同的 就执行count++, 否则就count--, 当count==0时, 就改变res的值为当前遍历的值,

这样一来, 无论数组里的元素顺序如何, 最后res里的值都会是我们的多数元素,

如果遍历到我们的多数元素res中记录的正好是这个值, 那么count++, 就想当与支持者给自己投了支持票, 如果遍历到多数元素时, res中记录的是别的数字, 那么count--, 就相当于自己的支持者给别人投了反对票, 不管怎么样, 多数元素的票的总量多余其他所有元素之和, 所以最后res的值一定就是我们的多数元素.

java

class Solution {public int majorityElement(int[] nums) {int res = -1, count = 0;for (int num : nums) {if (count == 0) {res = num;count = 1;} else if (res == num ) {count ++;} else {count --;}}return res;}
}

C++

class Solution {
public:int majorityElement(vector<int>& nums) {int res = -1, count = 0;for (int num : nums) {if (count == 0) {res = num;count = 1;} else if (res == num ) {count ++;} else {count --;}}return res;}
};
http://www.sczhlp.com/news/67363/

相关文章:

  • 外贸网站图片素材种子搜索引擎
  • 辽宁鹤城建设集团网站wordpress多语言子域名
  • 广州海珠网站开发定制哪有专做飞织鞋面的网站
  • 佛山的网站建设公司scrm
  • 百度网站推广公司佛山做网站哪家好
  • 西部数码网站管理助手3.0网站建设咨询哪些方面
  • 微网站建设方案财政达濠网红景点
  • 网站中文名称发软文提高网站权重
  • Java反射
  • 0120_桥接模式(Bridge)
  • 网站建设公司济南微信公众平台登录方法
  • vs2010网站开发实例郑州短视频推广
  • 东莞专业微网站建设价格低linux wordpress安装
  • wordpress不安装先写前端浙江seo
  • 做音乐 交流网站重庆seo管理平台
  • 深圳场站建设发展有限公司柳州团购汽车网站建设
  • 网站建设经营特色做网站到底要不要营业执照
  • 网站 配色专门做微信推送的网站
  • 广州网站建设广州网络推广公司衡阳网站建设衡阳千度网络
  • 做模具的都有什么网站常州做网站的公司
  • 百度一直不收录网站天津建设工程信息网投标信息系统
  • 三亚网站外包网站专用app
  • 一级a做爰片官方网站wap网站分享代码
  • 网站的301重定向怎么做wordpress数据在哪个文件夹
  • 重庆装修公司十大排名seo视频
  • b
  • 跑纸活做网站免费域名注册个人服务器搭建
  • 一流的商城网站建设天津网站建设哪家公司好
  • 用cms做网站的缺点网站设计软件手机版
  • APP手机端电子商务网站建设网站开发工程师php岗位职责