lintcode 落单的数(位操作)

题目1 落单的数

  给出2*n + 1 个的数字,除其中一个数字之外其他每个数字均出现两次,找到这个数字。

  链接:http://www.lintcode.com/zh-cn/problem/single-number/

样例

  给出 [1,2,2,1,3,4,3],返回 4

挑战

  一次遍历,常数级的额外空间复杂度

解决方案

  方法1思路:将所有的数转换成二进制,因为是int类型,共32位。申请常数级(32位)的额外空间,然后每个数对应的位相加,最后对应位上的和模2。最后的结果就是单个数对应的二进制数。

class Solution {
public:/*** @param A: Array of integers.* return: The single number.*/int singleNumber(vector<int> &A) {// write your code hereint ans[35];memset(ans, 0, sizeof(ans));for(int i=0; i<A.size(); ++i){for(int k=0; k<32; k++)ans[k] = (ans[k]+((A[i]>>k)&1))%2;}int ret = 0;int base = 1;for(int i=0; i<32; ++i){ret += ans[i]*base;base *= 2;}return ret;}
};

  方法2思路:通过异或,相同的数结果为0,那么最后的结果一定是落单的数字。

class Solution {
public:/*** @param A: Array of integers.* return: The single number.*/int singleNumber(vector<int> &A) {// write your code hereint ans = 0;for(int i=0; i<A.size(); ++i)ans ^= A[i];return ans;}
};

题目2 落单的数 II

  给出3*n + 1 个的数字,除其中一个数字之外其他每个数字均出现三次,找到这个数字。

  链接:http://www.lintcode.com/zh-cn/problem/single-number-ii/

样例

  给出 [1,1,2,3,3,3,2,2,4,1] ,返回 4

挑战

  一次遍历,常数级的额外空间复杂度

解决方案

  同上一题的方法1一样的思路。

class Solution {
public:/*** @param A : An integer array* @return : An integer */int singleNumberII(vector<int> &A) {// write your code hereint ans[35];memset(ans, 0, sizeof(ans));for(int i=0; i<A.size(); ++i){for(int k=0; k<32; k++)ans[k] = (ans[k]+((A[i]>>k)&1))%3;}int ret = 0;int base = 1;for(int i=0; i<32; ++i){ret += ans[i]*base;base *= 2;}return ret;}
};

 

题目3:落单的数 III

  给出2*n + 2个的数字,除其中两个数字之外其他每个数字均出现两次,找到这两个数字。

  链接:http://www.lintcode.com/zh-cn/problem/single-number-iii/

样例

  给出 [1,2,2,3,4,4,5,3],返回 1和5

挑战

  O(n)时间复杂度,O(1)的额外空间复杂度

解决方案

      

  如上图所示,所有数的异或的结果等于两个落单数异或的结果(设为S)。如何根据这个异或的结果将落单的数找出来呢?首先,S的值一定不为0,那么找到S对应的二进制数值为1的位(找到任意一个位为1都行, 这里我们找到S的二进制最后一个为1的位,设为P),根据这一个位置,将所有的数划分成两部分,一部分是对应二进制P位是1,另一部分对应二进制P位是0。这样就把两个落单的数划分到了不同的集合里去了。如上图的红色框集合和绿色框集合。然后就转换成“2*m+1个数字,除了一个数字其他数字均出现两次”的问题,也就是题目1:落单的数I

class Solution {
public:/*** @param A : An integer array* @return : Two integers*/int findNum(int k, vector<int> &A, bool flag){int ret = 0;for(int i=0; i<A.size(); ++i){if(flag && (1<<k)&A[i])ret ^= A[i];if(!flag && !((1<<k)&A[i]))ret ^= A[i];}return ret;}vector<int> singleNumberIII(vector<int> &A) {// write your code hereint x = 0;for(int i=0; i<A.size(); ++i)x ^= A[i];int k = 0;for(k; k<32; ++k)//找到异或值最后一个1,说明该位置P之后,两个不同的数对应的二进制是相同的if((1<<k)&x)break;//根据这个位置P,转换成“2*m+1个数字,除了一个数字其他数字均出现两次”的问题//将位置P上对应为1的数字异或得到一个数字,然后再将位置P上对应为0的数字异或得到一个数字,最后得到答案vector<int> ans;ans.push_back(findNum(k, A, true));ans.push_back(findNum(k, A, false));return ans;}
};

 

转载于:https://www.cnblogs.com/hujunzheng/p/5045084.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/531368.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

旋转图像

旋转图像 给定一个NN的二维矩阵表示图像&#xff0c;90度顺时针旋转图像。 看个例子 算法1&#xff1a; 如上图所示&#xff0c;设一个N阶二维矩阵&#xff0c;则将矩阵从外向里可以分成N/2个圈&#xff0c;例如&#xff08;1 2 3 4 8 12 16 15 14 13 9 5&#xff09;这是最外边…

嵌入式开发板模拟器:QEMU

前两天看微信公众号时发现了一个嵌入式模拟器&#xff0c;感觉很不错&#xff0c;自己动手安装了一个&#xff0c;折腾了几天&#xff0c;下载一直是个问题&#xff0c;特此记录如下 模拟器大家应该都听说过&#xff0c;有的小伙伴打游戏也会安装模拟器&#xff0c;今天我们介绍…

gcc: weak_alias如何使用

本文主要说明weak和alias是什么和如何使用它 __attribute__是用来说明函数的属性&#xff0c;weak和alias分别是两个属性。 &#xff08;一&#xff09;强符号和弱符号&#xff1a; 强符号&#xff1a;已经初始化的全局变量和未被weak修饰的函数弱符号&#xff1a;未初始化的全…

静态Include和动态Include测试并总结

主要代码 hjzgg.css .center-div{width:auto;margin-left: 40%;margin-right: 40%;display: block;position: absolute;top:0px;left:0px; }.text-div{margin-top: 80px; }.hjzgg-div{color:transparent;font-size:20px;font-weight: bold;letter-spacing:2px;-webkit-animatio…

linux终端常用快捷键

CTRLALTT 打开终端 CTRLD 关闭终端 CTRL SHIFT "" 放大终端字体 CTRL “-” 缩小终端字体 CTRL r 查找历史命令 CTRLu 删除光标前面所有内容 CTRLw 删除光标左边的单词 CTRL k 删除光标后面的所有内容 CTRLL 清除当前屏幕内容 CTRLa 光标移到开始位置 CTRLe 光标移到…

ueditor的配置和使用

ueditor下载好之后直接复制到项目的WebContent目录下&#xff0c;并将ueditor\jsp\lib下的jar包复制或者剪切到项目的lib目录下。先看一下效果&#xff0c;如下&#xff1a; 1.文件的上传 首先在ueditor/jsp目录下找到config.json文件&#xff0c;就拿Image上传来说吧。 "…

windows上搭建NFS服务器

在进行嵌入式开发的时候&#xff0c;我们常用的做法是搭建NFS服务器&#xff0c;然后使把文件系统、调试程序放在NFS服务器上&#xff0c;这样可以方便调试&#xff0c;以前都是在linux里面开启NFS服务器&#xff0c;今天来说下window里的nfs服务器–haneWin 一、软件安装和使…

计算机是如何启动的?从未上电到操作系统启动

计算机是如何启动的&#xff0c;网络上很多博文1都从 BIOS 程序的加载开始说起&#xff0c;有的也跳到 BIOS 程序加载 Bootloader 阶段。个人认为把这个过程称为操作系统是如何被加载并启动应该更加贴切一点。同时&#xff0c;也有计算机硬件大神的文章[1][5]详细分析计算机加电…

Hibernate注解

前言&#xff1a; 最近正在学习Hibernate通过注解&#xff08;annotation&#xff09;来管理映射关系&#xff0c;以前都是通过XML映射文件。下面拿个小例子说一下。 数据库物理模型&#xff1a; 数据库的描述&#xff1a; 一篇博客随笔可以分到不同的类中&#xff0c;一个类中…

js表单动态添加数据并提交

情景1&#xff1a;已经存在form对象了&#xff0c;动态为form增加对象并提交 function formAppendSubmit(){var myform$(#newArticleForm); //得到form对象var tmpInput$("<input typetext nameblogArticleForm.articleContent/>");tmpInput.attr("value&…

*++p和*p++的区别

首先你应该明白* 和 的优先级是相同的&#xff0c;而且他们的结合性是从又往左的 #include <stdio.h>int main(int argc ,char * argv[]) {int str[]{1,2,3,4,5,6,7,8,9,10};int *p str;int a *p;//a*p ,pp1即a1&#xff0c;p&str[1]int b *p;//pp1,b*p即p&s…

zyUpload+struct2完成文件上传

前言&#xff1a; 最近在写自己的博客网站&#xff0c;算是强化一下自己对s2sh框架的理解。期间遇到了很多问题&#xff0c;这些问题在写之前都考虑过&#xff0c;感觉也就是那样吧。但正真遇到了&#xff0c;也挺让人难受的。就利用zyUpload这个js插件实现文件的上传&#xff…

gbd的简单使用(一)

这篇文章将gdb的简单使用&#xff0c;通过此篇文章你能学习到使用gdb进行调试程序 在Linux中编写程序时&#xff0c;如何进行程序的debug工作呢&#xff1f;今天来介绍下gdb这个工具&#xff0c;可以在Linux下直接man gdb查看帮助信息 &#xff08;一&#xff09;gdb命令介绍 …

java发送内嵌图片邮件

前言&#xff1a; 博客系统中需要邮件服务的功能&#xff0c;以前写过类似的功能&#xff0c;不过功能太简单了&#xff0c;仅仅是发送文本内容&#xff0c;现在尝试一下发送内嵌图片邮件&#xff01; 准备工作&#xff1a; 请参考&#xff1a;http://www.cnblogs.com/hujunzhe…

调试跟踪利器---strace

通过这篇文章你会学习到strace的用法&#xff0c;strace可以帮助你高效地定位进程中的一些错误&#xff0c;关于strace的用处有很多&#xff0c;可以自行发掘 前面我们讲解了gdb调试程序,这篇文章介绍另一个调试跟踪工具strace&#xff0c;同样你可以在linux下执行man strace查…

MBR、DBR、FAT32基础小知识

MBR-------主引导记录 1.创建时间&#xff1a;由分区软件&#xff08;Fdisk/PartitionMagic/Windows 2000/Windows XP安装 工具等&#xff09;给 硬盘分区时建立的。 2.功能 &#xff1a;存放硬盘分区信息和引导系统时检查分区。 3.作用范围&#xff1a;MBR和虚拟MBR控制着整个…

java使用Executor(执行器)管理线程

一.一个实现了Runnable接口的类 class MyThread implements Runnable{private static int num 0;Overridepublic void run() {while(true){synchronized(MyThread.class){num;try{Thread.sleep(500);} catch(Exception e){System.out.println(e.toString());}System.out.print…

JMM和happens-before原则

JMM&#xff1a; Java Memory Model(Java内存模型)&#xff0c;围绕着在并发过程中如何处理可见性、原子性、有序性这三个特性而建立的模型。 可见性&#xff1a; JMM提供了volatile变量定义、final、synchronized块来保证可见性。  例如&#xff1a;线程a在将共享变量x1写入…

SD卡移植FAT32文件系统无MBR

问题&#xff1a;在研究SD卡和FAT32文件系统的时候&#xff0c;发现SD卡有的有MBR&#xff0c;有的没有MBR&#xff0c;这个为什么呢&#xff1f; 分析&#xff1a;MBR是主引导记录&#xff0c;是在给磁盘分区的时候建立的&#xff0c;我们的SD卡没有这个可能就是没有进行过分区…

java获取类的信息

关键技术剖析 1.java.lang.reflect包实现了java的反射机制&#xff0c;在使用反射机制时&#xff0c;需要导入该包。 2.Class类的forName方法能够根据类名加载类&#xff0c;获得类的Class对象。 Class类的getSuperclass方法获得父类的Class对象&#xff1b;getDeclaredFields方…