Thursday, January 24, 2013

Algorithm Questions

1. How to reverse a single linked list?
    Solution:- Try a program to reverse the node references (instead of current to next change it to next to    
    current) using a temp variable.

2. How to reverse a String?
    Solution:-
   public String reverse(String str) {
    char[] chars = str.toCharArray();
    int n = chars.length;
    for (int i = 0; i < n/2; i++) {
        char tmp = chars[i];
        chars[i] = chars[n-i-1];
        chars[n-i-1] = tmp;
    }
    return new String(chars);
}
3. Find out number of bits needed to represent a positive integer in binary?
      Solution:-
       Just count how many times you shift right before you're left with just zero:
int value = 11;
int count = 0;
while (value > 0) {
    count++;
    value = value >> 1;
}

4. Java program to get the max number in an array?
Solution:
 max = 0;
            
            for (int i = 0; i < array.length; i++) 
            {
                if(max < array[i])
                {
                   max = array[i]; 
                }
            }
5. If you have access to a function that returns a random integer from one to five, write another function which returns a random integer from one to seven.
  Random r1 = new Random();
  Random r2= new Random();
  int m=0;
  while(m<=7){
   int k = r1.nextInt(5);
   int l = (r2.nextInt(5)/2);
   int n = (r2.nextInt(5)/3);
   m = l+k+n;
   System.out.println(m);
   if(m==7){
    break;
   }
  }
6. 

What order is a hash table lookup? 

--Hashtables are sorted by some hash function, not by their natural sort order, so you'd have to extract all the entries O(N) and sort them O(NlogN) 


7. What order is determining if a number is even or odd? 1

8. What order is finding an item in an unsorted list? n square

9. What order is a binary search? log n (because n/2)

10. 
Given an array of size n, containing every element from 1 to n+1, except one. Find the missing element.


    Solution :-   (Sum of all the elements from 1 to n+1)  - (Sum of all the elements in the array)


11. Sum of elements from 1 to n is n*(n+1)/2


12. Factorial:-

protected static long fact (int n)
{
if (n <= 1)
return 1;
return n * fact (n - 1);
} // method fact

14. Queue using stack:-
2 Stacks:-

Keep 2 stacks, let's call them inbox and outbox.
Queue:
- Push the new element onto inbox
Dequeue:
- If outbox is empty, refill it by popping each element from inbox and pushing it onto outbox
- Pop and return the top element from outbox
Using this method, each element will be in each stack exactly once - meaning each element will be pushed twice and popped twice, giving amortized constant time operations.
Here's an implementation in Java:
public class Queue<E>
{

    private Stack<E> inbox = new Stack<E>();
    private Stack<E> outbox = new Stack<E>();

    public void queue(E item) {
        inbox.push(item);
    }

    public E dequeue() {
        if (outbox.isEmpty()) {
            while (!inbox.isEmpty()) {
               outbox.push(inbox.pop());
            }
        }
        return outbox.pop();
    }

}

1 Stack:-

public class SimulatedQueue<E> {
    private java.util.Stack<E> stack = new java.util.Stack<E>();

    public void insert(E elem) {
        if (!stack.empty()) {
            E topElem = stack.pop();
            insert(elem);
            stack.push(topElem);
        }
        else
            stack.push(elem);
    }

    public E remove() {
        return stack.pop();
    }
}
13. http://www.careercup.com/question?id=15421717

No comments: