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

太仓网站制作书生站长源码

太仓网站制作书生,站长源码,做黄网站,山西 网站制作【LetMeFly】260.只出现一次的数字 III 力扣题目链接:https://leetcode.cn/problems/single-number-iii/ 给你一个整数数组 nums,其中恰好有两个元素只出现一次,其余所有元素均出现两次。 找出只出现一次的那两个元素。你可以按 任意顺序 返…

【LetMeFly】260.只出现一次的数字 III

力扣题目链接:https://leetcode.cn/problems/single-number-iii/

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

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

 

示例 1:

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

示例 2:

输入:nums = [-1,0]
输出:[-1,0]

示例 3:

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

 

提示:

  • 2 <= nums.length <= 3 * 104
  • -231 <= nums[i] <= 231 - 1
  • 除两个只出现一次的整数外,nums 中的其他数字都出现两次

方法一:位运算(异或)

这道题的本质思路是:将所有的数分成两组,只出现了一次的数分别分到两组中,其余数根据“与单独的数的相似程度”分到这两个组中。这个过程保证了相等的两个数会被分到同一组中。

依据什么将只出现了一次的两个数分到两组中呢?我们只需要将所有的数异或,异或的结果就是“只出现一次的两个数”的异或结果。这两个数不相等,因此这个异或结果一定不为零。

异或结果中,为0的位代表两数这一位也相等,为1的位代表两数的这一位不同。那么,我们就可以根据这个异或结果的“最低一个不为0的位”为依据,将所有的数分为两组。这样,不相同的两个数一定会被分到不同的组中。

这样,对于单个组,只有一个只出现了一次的数字 和 出现了两次的数字,按照136.只出现一次的数字的方法分别提取出这两个数了。

关于如何求得一个数二进制下第一个不为0的位,可以依据lowbit的原理。

  • 时间复杂度 O ( l e n ( n u m s ) ) O(len(nums)) O(len(nums))
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
class Solution {
public:vector<int> singleNumber(vector<int>& nums) {unsigned int temp = 0;for (int t : nums) {temp ^= t;}int mask = temp & (-temp);vector<int> ans(2);for (int t : nums) {ans[(t & mask) != 0] ^= t;}return ans;}
};
Python
# from typing import Listclass Solution:def singleNumber(self, nums: List[int]) -> List[int]:temp = 0for t in nums:temp ^= tmask = temp & (-temp)ans = [0, 0]for t in nums:ans[(t & mask) != 0] ^= treturn ans

同步发文于CSDN,原创不易,转载经作者同意后请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/133872707

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

相关文章:

  • 南宁网站设计建设登封网站设计
  • wordpress多条件过滤廊坊网络推广优化公司
  • 王烨真实身份长沙seo推广
  • 网站毕设怎么做百度识图鉴你所见
  • 花生棒做网站aso应用商店优化原因
  • 青岛建站服务沈阳今日新闻头条
  • 公司请人做的网站 域名属于谁石家庄seo外包的公司
  • 做网站 支付账号免费吗谷歌搜索引擎下载
  • 如何做返利网站外推广网络营销工作内容是什么
  • nas建站品牌营销包括哪些内容
  • 阿里巴巴网站开发看网站搜索什么关键词
  • 微信群投票网站怎么做企业seo案例
  • 自助建站系统官方版网络优化工程师是干什么的
  • 网站备案信息真实性核验世界杯比分
  • apache 网站建设竞价推广课程
  • wordpress it模板下载北京seo顾问推推蛙
  • 网站开发的软件环境杭州百度推广代理商
  • 电信改公网ip可以做网站吗朋友圈推广平台
  • 领导视察网站建设杭州优化公司哪家好
  • 做内容网站 用什么模版网上软文发稿平台
  • 网站建设和优化要求关键词优化如何
  • 北京外包做网站如何报价樱桃电视剧西瓜视频在线观看
  • 太原网站建设策划方案ks数据分析神器
  • div css网站源代码网络推广平台代理
  • 网站购物车js代码怎么做微信小程序开发费用一览表
  • qq浏览器小程序入口西安关键词seo
  • 淘宝客如何做自己的网站如何创建属于自己的网站
  • 网站开发实训h5总结网址搜索引擎
  • 5建网站整站seo优化哪家好
  • 公司开发一个网站的流程电商详情页模板免费下载