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

用照片做的ppt模板下载网站北京seo加盟

用照片做的ppt模板下载网站,北京seo加盟,网站开发需求分析模板,电脑租赁掩码异或的作用前言一、按位与为零的三元组二、统计分组1、map统计分组2、异或掩码总结参考资料前言 当a b 0时,我们能够很清楚的知道b是个什么值,b 0 - a -a,如果当a & b 0时,我们能够很清楚的知道b是什么值吗&#xf…

掩码+异或的作用

  • 前言
  • 一、按位与为零的三元组
  • 二、统计分组
    • 1、map统计分组
    • 2、异或+掩码
  • 总结
  • 参考资料

前言

当a + b = 0时,我们能够很清楚的知道b是个什么值,b = 0 - a = -a,如果当a & b = 0时,我们能够很清楚的知道b是什么值吗?

一、按位与为零的三元组

在这里插入图片描述

二、统计分组

1、map统计分组

像这种组合题,纯靠for循环遍历出来的都会超时,一般用map/切片统计,通过乘法/加法,快速组合,或者说抽象的方式组合,只在乎组合的次数,不在乎具体的组合情况。
方法:先两层for循环,进行统计两数与完之后的分组情况,再来两层for循环,来寻找分组数据和第3个数与的情况。

func countTriplets(nums []int) int {// 分组cnt := map[int]int{}for i := 0;i < len(nums);i++ {for j := 0;j < len(nums);j++ {cnt[nums[i] & nums[j]]++}}// 计数ans := 0for k,v := range cnt {if k == 0 {ans += v * len(nums)continue}for _,n := range nums {if n & k == 0 {ans += v}}}return ans
}

2、异或+掩码

上面的解法只是进行了简单的分组,但是并未利用到与操作的特性,我们可以仔细分析与操作的特性,看能不能将第二个双层for循环变成单层for循环。

与操作为0,说明了三个数的每一位,必定有一个0及以上。
假设第一个双层for循环得到了一些数,这些数要和nums再组合一次,当前者的任意一位为1时,后者必须是0,当前者的任意一位为0时,后者可0可1。

可0可1?那怎么记录前者的“相反数”啊?
将一个值整成多份,每份将一个0变1,并记录这种数有一个,这样就不管匹配的什么可0可1了。
我们需要记录所谓的相反数,可通过掩码+异或的方式,来将0变1,1变0,再不断组合1的情况,并记录这些相反数的个数。

func countTriplets(nums []int) int {// 分组统计cnt := make([]int,1 << 16)cnt[0] = len(nums)const MAX = 1 << 16 - 1for i := 0;i < len(nums);i++ {mask := nums[i] ^ MAXfor j := mask;j > 0;j = (j - 1) & mask {cnt[j]++}}// 计数ans := 0for _,a := range nums {for _,b := range nums {ans += cnt[a & b] // 刚好01互补,mask+异或是个好东西}}return ans
}

总结

1)困难题都是各种组件组合而成,所以训练好各种问题的解决方式,再分析困难题的组合情况,就能快速解答困难题。
2)异或的作用蛮大的,配合掩码能将一个数的所有二进制取反。

参考资料

[1] LeetCode 按位与为零的三元组

http://www.hkea.cn/news/711847/

相关文章:

  • 武山建设局网站什么是seo
  • 做文案需要用到的网站全网模板建站系统
  • 苏州乡村旅游网站建设策划书网站建设百度推广
  • 12380网站建设情况总结百度浏览器入口
  • 直播网站开发要多久排行榜前十名
  • 网站备案完才能建站吗企业建站公司
  • 网站开发外包合同西安网站优化公司
  • 2022网页设计尺寸规范和要求怎么做seo关键词优化
  • 北京大学两学一做网站十大收益最好的自媒体平台
  • 网站开发服务费企业网站建设的一般要素
  • 台州企业网站制作公司郴州网站推广
  • 如何做移动端网站邮件营销
  • 网站制作佛山crm管理系统
  • 网站综合营销方案设计网页设计教程
  • 东莞做网站制作宁波技术好的企业网站制作
  • 广州做网站公司哪家好如何注册一个网站
  • 网站备案协议书互联网营销师证书含金量
  • 广州企业网站建设报价免费推广网站大全
  • 宁波网站排名怎么提交网址让百度收录
  • 杭州 手机网站建设活动营销
  • 加网络网站建设工作室做一个企业网站大概需要多少钱
  • 张家港优化网站seo百度网盘下载
  • 烟台有没有做网站网站安全
  • 网站建设与制作设计公司惠州seo代理商
  • 东营新闻网今日头条常州网站seo
  • 东莞全网合一网站黄页引流推广网站软件免费
  • wordpress的数据库在那里百度seo如何快速排名
  • wordpress手机客服代码免费seo快速排名工具
  • web网站开发作品关键词歌词图片
  • 汕头行业网站seo培训公司