博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode540
阅读量:6090 次
发布时间:2019-06-20

本文共 1006 字,大约阅读时间需要 3 分钟。

这道题目的要求,Note: Your solution should run in O(log n) time and O(1) space.

因此应该用二分查找的方式,代码如下:

1 class Solution: 2     def singleNonDuplicate(self, nums: 'List[int]') -> int: 3         l = 0 4         h = len(nums)-1         5         while l

52ms,13.8mb

 

传统的方式,就是已经两次遍历,先遍历一遍数组,记录每一个值出现的次数,存储到一个字典中。

然后再遍历一次字典,找到只出现一次的那个值,代码如下:

1 class Solution:2     def singleNonDuplicate(self, nums: 'List[int]') -> 'int':3         count = {}4         for num in nums:5             count[num] = count.get(num, 0)+1  6         for key in count:7             if count[key] == 1:8                 return key

48ms,14.5mb

这种方式想法很简单也很容易懂,但是需要额外的空间。但奇怪的是其执行时间却比二分查找的要快,感觉可能是测试集的样本问题。

 

还有一种技巧性比较强的方式,空间复杂度满足要求,但是时间复杂度应该更高:

1 class Solution:2     def singleNonDuplicate(self, nums: 'List[int]') -> 'int':3         res = nums[0]4         for i in range(1,len(nums)):5             res ^= nums[i]6         return res

60ms,14mb

最后贴上三种方法的执行结果,从上倒下分别是第三种,第二种和第一种,这种不对称就是破除强迫症的排版(其实是我比较懒)

转载于:https://www.cnblogs.com/asenyang/p/10433672.html

你可能感兴趣的文章
linux下查看各硬件型号
查看>>
epoll的lt和et模式的实验
查看>>
Flux OOM实例
查看>>
07-k8s-dns
查看>>
Android 中 ListView 分页加载数据
查看>>
oracle启动报错:ORA-00845: MEMORY_TARGET not supported on this system
查看>>
Go方法
查看>>
Dapper丶DapperExtention,以及AbpDapper之间的关系,
查看>>
搞IT的同学们,你们在哪个等级__那些年发过的帖子
查看>>
且谈语音搜索
查看>>
MySQL数据库导入导出常用命令
查看>>
低版本Samba无法挂载
查看>>
Telegraf+Influxdb+Grafana构建监控平台
查看>>
使用excel 展现数据库内容
查看>>
C#方法拓展
查看>>
MySql.Data.dll的版本
查看>>
Linux系统磁盘管理
查看>>
hdu 2191 (多重背包+二进制优化)
查看>>
home.php
查看>>
neo4j---删除关系和节点
查看>>