Find a duplicate element in an array - 我的博客 - ITeye技术网站



Find a duplicate element in an array - 我的博客 - ITeye技术网站

Suppose you have an array of 1001 integers. The integers are in random order, but you know each of the integers is between 1 and 1000 (inclusive). In addition, each number appears only once in the array, except for one number, which occurs twice. Assume that you can access each element of the array only once. Describe an algorithm to find the repeated number. If you used auxiliary storage in your algorithm, can you find an algorithm that does not require it?

 

如果可以用辅助空间的话,可以用HashSet来处理,如果add失败说明有重复的。但是如果不能用额外空间的话呢?

 

Solution 1:

考虑加法。1+2+...+n = n(n-1)/2

假设数组所有元素之和为sum, 那么sum-n(n-1)/2就是我们要找的重复的数。

Java代码  收藏代码
  1. public int findDuplicate(int[] nums) {  
  2.     int sum = 0;  
  3.     int n = nums.length;  
  4.     int expected = n*(n-1)/2;  
  5.     for(int i=0; i<n; i++) {  
  6.         sum += nums[i];  
  7.     }  
  8.     return sum-expected;  
  9. }  

但是数组的元素数达到或接近INT_MAX的时候, 加法运算就会溢出。我们还可以考虑位运算XOR。

XOR具有以下性质:

交换律A \oplus B = B \oplus A

结合律A \oplus (B \oplus C)=(A \oplus B) \oplus C

恒等律X\oplus 0=X

归零律X\oplus X=0

自反A \oplus B \oplus B=A\oplus 0=A

假设给定数组A[6] = {5,2,3,4,3,1},而我们期望的数组应该为A[6]={0,1,2,3,4,5}。其中我们用0来代替重复的元素。

接下来对给定数组和我们期望数组的所有元素做异或运算:

(5^0)^(2^1)^(3^2)^(4^3)^(3^4)^(1^5)

= (5^5)^(2^2)^(3^3)^(4^4)^(1^1)^(3^0)

= 0^3

= 3

写成代码则非常简单。


Read full article from Find a duplicate element in an array - 我的博客 - ITeye技术网站


No comments:

Post a Comment

Labels

Algorithm (219) Lucene (130) LeetCode (97) Database (36) Data Structure (33) text mining (28) Solr (27) java (27) Mathematical Algorithm (26) Difficult Algorithm (25) Logic Thinking (23) Puzzles (23) Bit Algorithms (22) Math (21) List (20) Dynamic Programming (19) Linux (19) Tree (18) Machine Learning (15) EPI (11) Queue (11) Smart Algorithm (11) Operating System (9) Java Basic (8) Recursive Algorithm (8) Stack (8) Eclipse (7) Scala (7) Tika (7) J2EE (6) Monitoring (6) Trie (6) Concurrency (5) Geometry Algorithm (5) Greedy Algorithm (5) Mahout (5) MySQL (5) xpost (5) C (4) Interview (4) Vi (4) regular expression (4) to-do (4) C++ (3) Chrome (3) Divide and Conquer (3) Graph Algorithm (3) Permutation (3) Powershell (3) Random (3) Segment Tree (3) UIMA (3) Union-Find (3) Video (3) Virtualization (3) Windows (3) XML (3) Advanced Data Structure (2) Android (2) Bash (2) Classic Algorithm (2) Debugging (2) Design Pattern (2) Google (2) Hadoop (2) Java Collections (2) Markov Chains (2) Probabilities (2) Shell (2) Site (2) Web Development (2) Workplace (2) angularjs (2) .Net (1) Amazon Interview (1) Android Studio (1) Array (1) Boilerpipe (1) Book Notes (1) ChromeOS (1) Chromebook (1) Codility (1) Desgin (1) Design (1) Divide and Conqure (1) GAE (1) Google Interview (1) Great Stuff (1) Hash (1) High Tech Companies (1) Improving (1) LifeTips (1) Maven (1) Network (1) Performance (1) Programming (1) Resources (1) Sampling (1) Sed (1) Smart Thinking (1) Sort (1) Spark (1) Stanford NLP (1) System Design (1) Trove (1) VIP (1) tools (1)

Popular Posts