136. Single Number

Easy

Given a non-empty array of integers, every element appears twice except for one. Find that single one.

Note:

Your algorithm should have a linear runtime complexity. Could you implement it without using extra memory?

Example 1:

Input: [2,2,1]
Output: 1

Example 2:

Input: [4,1,2,1,2]
Output: 4
package leetcode.easy;

import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set; public class SingleNumber {
@org.junit.Test
public void test() {
int[] nums1 = { 2, 2, 1 };
int[] nums2 = { 4, 1, 2, 1, 2 };
System.out.println(singleNumber1(nums1));
System.out.println(singleNumber1(nums2));
System.out.println(singleNumber2(nums1));
System.out.println(singleNumber2(nums2));
System.out.println(singleNumber3(nums1));
System.out.println(singleNumber3(nums2));
System.out.println(singleNumber4(nums1));
System.out.println(singleNumber4(nums2));
} public int singleNumber1(int[] nums) {
HashSet<Integer> set = new HashSet<Integer>();
int result = 0;
for (int i = 0; i < nums.length; i++) {
if (!set.contains(nums[i])) {
set.add(nums[i]);
} else {
set.remove(nums[i]);
}
}
Iterator<Integer> it = set.iterator();
while (it.hasNext()) {
result = it.next();
}
return result;
} public int singleNumber2(int[] nums) {
HashMap<Integer, Integer> map = new HashMap<Integer, Integer>();
int result = 0;
for (int i = 0; i < nums.length; i++) {
if (!map.containsKey(nums[i])) {
map.put(nums[i], 1);
} else {
map.remove(nums[i]);
}
}
Set<Integer> set = map.keySet();
Iterator<Integer> it = set.iterator();
while (it.hasNext()) {
result = it.next();
}
return result;
} public int singleNumber3(int[] nums) {
HashSet<Integer> set = new HashSet<Integer>();
int sumSet = 0;
int sum = 0;
for (int i = 0; i < nums.length; i++) {
set.add(nums[i]);
sum += nums[i];
}
Iterator<Integer> it = set.iterator();
while (it.hasNext()) {
sumSet += it.next();
}
return 2 * sumSet - sum;
} public int singleNumber4(int[] nums) {
int a = 0;
for (int i = 0; i < nums.length; i++) {
a ^= nums[i];
}
return a;
}
}

最新文章

  1. 《In Search of an Understandable Consensus Algorithm》翻译
  2. 使用NVelocity生成内容的几种方式
  3. 《Inside UE4》-1-基础概念
  4. openfire+asmack搭建的安卓即时通讯(三) 15.4.9
  5. Linux命令工具 top详解
  6. 【Memcache】下载和安装
  7. [置顶] 很荣幸被选为2013年度 CSDN博客之星评选,如果觉得我的文章可以,请投我一票!
  8. Cogs 1844. [JSOI2008]最大数maxnumber
  9. 转:聊聊并发(八)——Fork/Join框架介绍
  10. (原)java中opencv的width的问题
  11. Spring Boot 系列教程6-全局异常处理
  12. 转换器4:手写PHP转Python编译器,语法解析部分
  13. 爬虫不过如此(python的Re 、Requests、BeautifulSoup 详细篇)
  14. 【mysql】工作中mysql常用命令及语句
  15. django之ORM专项训练之图书信息系统 了不起的双下方法实战 和 分组 聚合 Q, F查询,有約束和無約束
  16. 连接mysql连接不上遇到的问题
  17. centos7.2 get pid by process name with python3.6
  18. zabbix短信监控
  19. python入门13 集合set
  20. win10 解决“ &#39;g++&#39; 不是内部或外部命令,也不是可运行的程序或批处理文件”的问题

热门文章

  1. 大数据之路week07--day01(HDFS学习,Java代码操作HDFS,将HDFS文件内容存入到Mysql)
  2. [TypeScript] vs code TSLint常见错误解决方案
  3. Vue项目中v-bind动态绑定src路径不成功
  4. Java Redis+Spring-data-redis 队列 单机版
  5. CSS 布局和 BFC
  6. Java中BigDecimal的equals与compareTo的区别
  7. codeforces#1228E. Another Filling the Grid(容斥定理,思维)
  8. 纯JS 10分钟 实现图片懒惰加载
  9. Spring框架各模块功能介绍
  10. Leetcode题目617:合并二叉树(递归-简单)