Algorithm Puzzle: Triplets in Array

Source: Asked to me by Anuj Jain (EE IITB 2010 Graduate, MFE Student at Baruch College NY)

Problem:
Given an array of n integers, find an algorithm to find triplets in the array such that sum of the three numbers is zero.

What is the order of your algorithm? Make sure its quadratic in size of array. :-)





Comments

  1. Have a solution in quadratic time and linear extra space:

    Step 1: Sort the array - O(n^2) time

    Step 2: Find the largest negative number in the array (there has to be one for such a triplet to exist) - O(log n) time

    Step 3: Iterate over the negative numbers like this:

    For every negative number k, look for existence of two numbers whose difference is -k.

    To do this, subtract n from every integer in array and copy to second array. Now do a pass over both arrays similar to a pass done while merging two sorted arrays.

    In this way we can get two numbers whose difference is -k in 0(n) time and O(n) space. And we do this for every negative number. So total order is O(n^2)...

    Hence total time is O(n^2) and space is O(n).

    Btw we can easily forgo O(n) space as well, just by remembering to add k to numbers in second array while comparing...

    Reply Delete
  2. sort the array; O(nlogn)

    now for i = 1,2..N

    find a(j) and a(k) (j,k >i) such that a(j)+a(k)=-a(i)

    this can be done in O(n) time as follows

    let y = -a(i)
    j = (i+1)
    k = (n)

    if y = a(j)+a(k) return (j,k);
    if y> a(j)+a(k) j=j+1;
    if y< a(j)+a(k) k = k-1;
    if j=k return not found; try next i i=i+1;

    Reply Delete
  3. Create 2 arrays from the input Array

    A with all elements >= 0
    B with all elements < 0 [n]

    Sort both the arrays (merge-sort) [WorstCase: 2n.log(n)]
    //A is sorted in decending order, B in Asscending

    i=0, j=0

    while(i < A.length && j < B.length)
    {

    if (A[i] > -B[j])
    {
    Let X = -A[i] -B[j]
    Search for X in Array B. (binary search, B is sorted) [log(n)]

    if (X is found at index k)
    print(A[i],B[j],B[k]);

    i++;
    }
    else
    {
    Let X = -A[i] +B[j]
    Search for X in Array A. (binary search, A is sorted) [log(n)]

    if (X is found at index k)
    print(A[i],B[j],A[k]);

    j++;
    }

    }

    //the total complexity of above while loop [n.log(n)]

    ============================================

    time complexity slightly greater than 3n.log(n) + n

    Reply Delete
  4. Sort the elements,in O(nlogn) time, in increasing order.
    Let sum be S=0.
    For each element in the array A_i (for i from 1 to N)
    Compute S' = -A_i.
    left = i+1
    right = n
    while(leftS') \\Means you need to reduce the number.
    right--
    else
    left++
    end while
    end for

    The while loop takes only O(n) time.
    This can be seen by understanding that if a certain number can form a triplet, it will NOT be skipped.
    and since each step, left and right comes closer by 1 the order is O(n)

    Reply Delete
  5. setofTriplets = []
    def findTriplets(array):
    global setofTriplets
    array.sort()
    for i in range(len(array)):
    for j in reversed(range(len(array))):
    if array[i]<0 and array[j]>=0:
    sum = array[i]+array[j]
    needToFind = -1 * (array[i] + array[j])
    if needToFind in array:
    ans = [array[i], array[j], needToFind]
    setofTriplets.append(ans)


    findTriplets([-9, -4, -3, -1, 0, 1, 2, 6, 7, 8])
    print setofTriplets

    Reply Delete

Post a Comment

[フレーム]

Popular posts from this blog

Buying Dimsums

Source: Alok Goyal (Stellaris VP, Ex-Helion VC) puzzle blog Problem: A fast food restaurant sells dimsums in boxes of 7 and 3. What’s the greatest number of dimsums a person cannot buy. Generalize it for p and q where p and q are relatively prime. I loved the puzzle. Hope you enjoy it too.

Polya's Urn Problem

Puzzle: There are two urns with one ball each. Each of subsequent n-2 balls is placed into one of these urns, with probability proportional to the number of balls already in that urn. What is the expected number of balls in the smaller sized urn? Source: P. Winkler's Puzzles book. (Chapter: Probability). Solution: Highlight the part between the * symbols for the answer. * This problem can be reformulated as the following problem. Suppose I have a stack of black cards and one red card. Initially I take red card in my hand. Now I add black cards randomly between any two cards (so, initially its either above or below red). Note that the probability that I add the card above the red card, when x-1 is the number of cards above red and y-1 is the number of cards below red is x/(x+y). Let the problem be if red card is dividing the black cards into two sets, what is the expected number of black cards in the smaller section. So, we see that the two problems are equivalent. No...

(Advanced) Cheryl's Birthday Puzzle

Source: Sent to me by Prateek Chandra Jha (IIT Bombay) Problem: This problem is inspired by the Cheryl's Birthday Puzzle ( FB Post , Guardian Link ). Paul, Sam and Dean are assigned the task of figuring out two numbers. They get the following information: Both numbers are integers between (including) 1 and 1000 Both numbers may also be identical. Paul is told the product of the two numbers, Sam the sum and Dean the difference. After receiving their number, the following conversation takes place: Paul: I do not know the two numbers. Sam: You did not have to tell me that, I already knew that. Paul: Then I now know the two numbers. Sam: I also know them. Dean: I do not know the two numbers. I can only guess one which may probably be correct but I am not sure. Paul: I know which one you are assuming but it is incorrect. Dean: Ok, I also know the two numbers. What are the two numbers? Disclaimer: Its not a puzzle for 14-15 year olds like Cheryl's