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

数据结构与算法——1125—面试题位运算

1、有一个数字只出现一次

题目

存在一个数组nums,其中有一个数字只出现一次,其余数字均出现偶数次,求出这个出现一次的数字

解答

1、整体异或

2、先排序再比较

时间复杂度O(n*log2n)        空间复杂度O(log2n)

3、计数

把所有数字放入进map或者哈希表中,容器为key——value的存储方式,key是元素,value是这个元素出现的次数,此时遍历容器,找出出现元素为1的即可

如果使用map,时间复杂度为O(n*log2n)        如果使用哈希表,时间复杂度为O(n)

空间复杂度O(n)

4、暴力

顺序的取出数组中的每个元素与其余的每个元素进行比较,查看是否出现过

时间复杂度O(n**2)        空间复杂度O(1)

异或方法详解

遍历一遍,则时间复杂度为O(n),空间复杂度O(1)

2、位运算

与、位或、按位取反、左移、右移

位或——|:只要有1,结果位1——使用只有一位为1的数字向原数字上进行叠加,叠加特性

异或——^:相异为1,相同0

位与——&:只要有0,结果为0——检测某一位是否为1

按位取反——~:运算级别非常高

左移<<:左移尾部补0

右移>>:右移头部补与符号位相同的数字

3、逻辑运算符

&&——逻辑与        ||——逻辑或

逻辑运算符比位运算符优先级高,有短路原则

4、把十进制数字转为二进制

使用数字1与要检测的十进制数字进行位与,然后将数字1进行左移

5、有两个元素只出现一次

解答

1、整体异或——循环

2、找到一个非零位——将结果与其负数形式进行位与

3、按照找到的非零位的情况,将数组分为两组

4、各组内进行异或

3-4分组异或可以融合成一步,边循环边异或

代码

#include<iostream>
#include<vector>
using namespace std;void nonzero(vector<int>nums,int& ans0,int& ans1)
{int len = nums.size();if (len == 1 || len == 0){return;}int ans = 0;for (int v:nums)//整体异或{ans ^= v;}ans= ans & (-ans);	//找到非零位for(int v:nums){//分组(ans& v) ? ans0 ^= v : ans1 ^= v;}
}int main()
{vector<int> nums = { 15,2,12,3,15,12,3,6,2,9 };int ans0 = 0;int ans1 = 0;nonzero(nums, ans0, ans1);cout << ans0 << "   " << ans1;return 0;
}

http://www.mrgr.cn/news/78504.html

相关文章:

  • 【Java基础】Java异常捕捉,throws/throw、finally、try、catch关键字的含义与运用
  • window.open 被浏览器拦截解决方案
  • 2025第2周 | JavaScript中的函数的参数默认值和剩余参数
  • .NET Core FluentAPI
  • C++ Latch 和 Barrier: 新手指南
  • ESP32-C3 AT WiFi AP 启 TCP Server 被动接收模式 + BLE 共存
  • redis的主从复制
  • 【通用】操作系统 知识总结:IPC方式 / 进程线程 / 死锁 / 虚拟内存 / 段页存储
  • Oracle对比表与表之间的结构
  • 20241128解决Ubuntu20.04安装libwxgtk3.0-dev异常的问题
  • linux内核面试题精选及参考答案
  • 探讨播客的生态系统
  • 零基础快速掌握——C语言基础【数据类型】【运算符】
  • python array矩阵相关操作
  • 《操作系统 - 清华大学》6 -1:局部页面置换算法:最优页面置换算法
  • 针对Qwen-Agent框架的Function Call及ReAct的源码阅读与解析:Agent基类篇
  • Robot Framework框架中常用的变量
  • A052-基于SpringBoot的酒店管理系统
  • Flink 离线计算
  • ais_server 学习笔记
  • mongodb文档字符串批量替换
  • JAVA项目-------医院挂号系统
  • vue3 tinymce7版本 完美适配基本需求(特殊需求外)
  • 【JavaEE初阶 — 网络编程】TCP流套接字编程
  • 《Learn Three.js》学习(2)构建Three.js基本组件
  • nginx安装和负载均衡