温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

c++中摩尔投票法如何使用

发布时间:2022-03-17 15:58:50 来源:亿速云 阅读:215 作者:iii 栏目:大数据

这篇“c++中摩尔投票法如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“c++中摩尔投票法如何使用”文章吧。

算法:

 典型的摩尔投票法使用场景

 摩尔投票法分为两个阶段:抵消阶段和计数阶段。

1. 抵消阶段:两个不同投票进行对坑,并且同时抵消掉各一张票,如果两个投票相同,则累加可抵消的次数;2. 计数阶段:在抵消阶段最后得到的抵消计数只要不为0,那这个候选人是有可能超过一半的票数的, 为了验证,则需要遍历一次,统计票数,才可确定。 备注:对于1/3,1/4.....1/n,做法就是设置n-1个投票候选人,采用摩尔投票的方法进行操作。

题目1: 超过半数的多数元素

代码实现:

func majorityElement(nums []int) int {    tmp,count := 0,0    for _,num:=range nums {        if count == 0 {            tmp = num        }        if num == tmp {            count++        } else {            count--        }    }    return tmp}// 算法:数组里面有一个数超过一半数量,// 那么可以用这个数作为标示,这个数就+1,不是这个数就-1,最后剩余的数就是所求

题目2: 求众数

代码实现:

func majorityElement(nums []int) []int {  // 创建返回值  var res = make([]int, 0)  if nums == nil || len(nums) == 0 {    return res  }
 // 初始化两个候选人 candidate,以及他们的计数票  cand1 := nums[0]  count1 := 0  cand2 := nums[0]  count2 := 0
 //摩尔投票法  // 配对阶段  for _, num := range nums {    // 投票    if cand1 == num {      count1++      continue    }    if cand2 == num {      count2++      continue    }
   if count1 == 0 {      cand1 = num      count1++      continue    }    if count2 == 0 {      cand2 = num      count2++            continue    }
   count1--    count2--  }  // 计数阶段  count1 = 0  count2 = 0  for _, num := range nums {    if cand1 == num {      count1++    } else if cand2 == num {      count2++    }  }
 if count1 > len(nums)/3 {    res = append(res, cand1)  }  if count2 > len(nums)/3 {    res = append(res, cand2)  }  return res}// 算法:摩尔投票法的应用// 因为是1/3,所以采用2个候选人来进行抉择。

以上就是关于“c++中摩尔投票法如何使用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++
AI