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

行政单位门户网站建设方案长沙网站推广工具

行政单位门户网站建设方案,长沙网站推广工具,薪酬体系搭建工具,网站改版的方式大致为前言 今天遇到一个位运算的题目,感觉很有意思,记录一下。 Question1 136. 只出现一次的数字 给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。 你必须设计并实…

前言

今天遇到一个位运算的题目,感觉很有意思,记录一下。

Question1

136. 只出现一次的数字

给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。

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

Solution

拿到题目,可以首先可以想到最暴力的解法,首先遍历整个数组,将每个元素的数量都存在map中,随后遍历map即可得出答案。时间复杂度O(N)、空间复杂度O(N)。显然不满足常量额外空间的要求。

更优一点的方法是使用异或操作,因为对同一个数的两次异或会返回原值(异或还经常用于加密领域,有一类密码叫做异或密码)。声明一个变量,随后遍历整个数组,对每个数都与此变量进行一次异或操作,最后这个值就是答案。

Code

func singleNumber(nums []int) int {var temp intfor _ , v := range nums{temp ^= v}return temp}

Question2

137. 只出现一次的数字 II

给你一个整数数组 nums ,除某个元素仅出现 一次 外,其余每个元素都恰出现 **三次 。**请你找出并返回那个只出现了一次的元素。

你必须设计并实现线性时间复杂度的算法且不使用额外空间来解决此问题。

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

Solution

同样的,这题的暴力解法也可以使用map,但是会有额外的O(N)空间复杂度。

这题异或好像使用不了,因为都是奇数,查看题解后发现,居然可以统计每一个比特位1的个数,将其做余3的操作后,就可以得到答案中此比特位的位。所以遍历31次,得到每一个比特位的值,再拼接成最后的答案即可。时间复杂度为O(32N)= O(N),空间复杂度为O(1),代码如下:

Code

func singleNumber(nums []int) int {result := int32(0)for i := 0; i < 32; i++ {num:=int32(0)for _,v := range nums {num	+=  (int32(v) >> i) & 1}if num % 3 > 0{result |= (1<<i)}}return int(result)}

Question3

137. 只出现一次的数字 III

给你一个整数数组 nums,其中恰好有两个元素只出现一次,其余所有元素均出现两次。 找出只出现一次的那两个元素。你可以按 任意顺序 返回答案。

你必须设计并实现线性时间复杂度的算法且仅使用常量额外空间来解决此问题。

输入:nums = [1,2,1,3,2,5]
输出:[3,5]
解释:[5, 3] 也是有效的答案。

Solution

同样的,这题的暴力解法也可以使用map,但是会有额外的O(N)空间复杂度。

这题可以使用异或来做,首先定义一个变量,将所有的数都与此变量进行异或,最后得到的结果就是两个只出现一次的异或的值。

通过这个值将nums里面的元素分为两组(两组中分别包含一个答案),对两组分别 使用异或,最后得到结果。

如何进行分组呢,我们的目的是两组汇总分别包含一个答案,所以可以根据两者的异或值,来找到某一个不一样的比特位,通过此比特位进行分组即可,代码如下:

Code

func singleNumber(nums []int) []int {
// 获得两个答案的异或值temp := 0for i := 0; i < len(nums); i++ {temp ^= nums[i]}//找到temp中第一个为1的比特位,根据异或的原理,说明在这个比特位上,两个答案一个为1,一个为0,以此比特位作为分组的依据index := 0for i := 0; i < 32; i++ {if (temp << i) & 1 == 1{index = ibreak}}var ans1 intvar ans2 intfor i := 0; i < len(nums); i++ {if (nums[i]<<i) & 1 == 0{ans1 ^= nums[i]}else{ans2 ^= nums[i]}}return []int{ans2,ans1}
}

总结

对于位运算的题目,要思考与、或、非、异或等操作,来合理完成题目的要求。

http://www.ds6.com.cn/news/66450.html

相关文章:

  • 网站制作用什么语言郑州网站关键词排名
  • 深圳做网站维护的公司看b站视频下载软件
  • html5 网站布局应用教程企业网站设计模板
  • 做网站前端设计需要哪些证书营销型网站建设价格
  • 做ppt素材网站哪个好营销课程培训视频
  • wordpress首页仅导航怎么设置沈阳seo代理计费
  • 建设工程部网站成人职业技能培训有哪些项目
  • dw怎么做鲜花网站北京seo招聘网
  • 万网网站建设的子分类能显示多少个南宁seo外包要求
  • 做网站需要买焦作关键词优化排名
  • 巴音郭楞网站建设长沙seo优化服务
  • 哪些是门户网站所有的竞价托管公司
  • 四核网站建设快速开发网站的应用程序
  • 一级造价工程师注册管理系统站长工具seo推广
  • 做网络兼职的网站我要登录百度
  • 联通公司做网站吗湖南百度seo排名点击软件
  • 没有网站也可以做外贸吗西安网站设计公司
  • 网站内链 工具hyein seo官网
  • 网易企业邮箱在苹果手机上怎么设置宁波优化推广选哪家
  • 哈尔滨网站建设b2b企业营销策划
  • 织梦装修公司网站模板广州顶正餐饮培训学校
  • 宁波市网站建设简述网站建设流程
  • 网站建设有几大板块安徽百度关键词优化
  • github主页做网站服务外包平台
  • 英文网站建设电话咨询长春网站建设公司哪个好
  • 深圳公司网站设计公网站关键词seo费用
  • 珠海外贸网站建设百度应用市场下载安装
  • 网站建设中如何插入动图深圳网络营销技巧
  • 哪些网站做兼职可靠吗国内最新新闻摘抄
  • 网站建设代码标准优秀网站网页设计