Wednesday, December 4, 2002

T R A N S P O S E A M A T R I X

package org.interview.test;

import java.util.Scanner;

/**
 * This code can be used to check if a matrix symmetric or not, 
 * just compare the matrix with it's transpose if they are same then it's 
 * symmetric otherwise non symmetric, also it's useful for calculating 
 * orthogonality of a matrix.
 * @author ADixit3034C
 *
 */
public class TransposeAMatrix {

public static void main(String args[])
  {
     int m, n, c, d;
 
     Scanner in = new Scanner(System.in);
     System.out.println("Enter the number of rows and columns of matrix");
     m = in.nextInt();
     n = in.nextInt();
 
     int matrix[][] = new int[m][n];
 
     System.out.println("Enter the elements of matrix");
 
     for ( c = 0 ; c < m ; c++ )
        for ( d = 0 ; d < n ; d++ )
           matrix[c][d] = in.nextInt();
 
     int transpose[][] = new int[n][m];
 
     for ( c = 0 ; c < m ; c++ )
     {
        for ( d = 0 ; d < n ; d++ )               
           transpose[d][c] = matrix[c][d];
     }
 
     System.out.println("Transpose of entered matrix:-");
 
     for ( c = 0 ; c < n ; c++ )
     {
        for ( d = 0 ; d < m ; d++ )
              System.out.print(transpose[c][d]+"\t");
 
        System.out.print("\n");
     }
  }
}

Tuesday, December 3, 2002

SWAP NUMBERS

package org.interview.test;

import java.util.Scanner;

public class SwapNumbers {

public static void main(String args[])
  {
swapNumberTemp();
swapNumWithOutTempVar();
  }

public static void swapNumWithOutTempVar () {
int x, y;
     System.out.println("Enter x and y");
     Scanner in = new Scanner(System.in);
 
     x = in.nextInt();
     y = in.nextInt();
 
     System.out.println("Before Swapping\nx = "+x+"\ny = "+y);
 
     x = x + y;
     y = x - y;
     x = x - y;
 
     System.out.println("After Swapping\nx = "+x+"\ny = "+y);
}

public static void swapNumberTemp(){
     int x, y, temp;
     System.out.println("Enter x and y");
     Scanner in = new Scanner(System.in);
 
     x = in.nextInt();
     y = in.nextInt();
 
     System.out.println("Before Swapping\nx = "+x+"\ny = "+y);
 
     temp = x;
     x = y;
     y = temp;
 
     System.out.println("After Swapping\nx = "+x+"\ny = "+y);
}

}

R E V E R S E A N U M B E R

package org.interview.test;

import java.util.Scanner;

public class ReverseANumber {

public static void main(String args[])
  {
     int n, reverse = 0;
 
     System.out.println("Enter the number to reverse");
     Scanner in = new Scanner(System.in);
     n = in.nextInt();
 
     while( n != 0 )
     {
         reverse = reverse * 10;
         reverse = reverse + n%10;
         n = n/10;
     }
 
     System.out.println("Reverse of entered number is "+reverse);
  }

}

P R I N T A L P H A B E T S

package org.interview.test;

public class PrintAlphabets {

public static void main(String [] args) throws Exception {
char x = 'a';

for (x ='a'; x <= 'z' ; x++) {
System.out.print(x);
}
System.out.println();

char y = 'a';
while (y <= 'z') {
System.out.print(y);
y++;
}

System.out.println();

char c = 'a';
do {
System.out.print(c);
c++;
} while (c <= 'z');
}
}

L I N E A R S E A R C H

package org.interview.test;

import java.util.Scanner;

/**
 * Above code locate first instance of element to found, you can modify it for multiple 
 * occurrence of same element and count how many times it occur in the list. 
 * Similarly you can find if an alphabet is present in a string.
 *
 */
public class LinearSearch {

public static void main (String [] args) throws Exception {
int c, n, search, array[];
 
   Scanner in = new Scanner(System.in);
   System.out.println("Enter number of elements");
   n = in.nextInt(); 
   array = new int[n];
 
   System.out.println("Enter " + n + " integers");
 
   for (c = 0; c < n; c++)
     array[c] = in.nextInt();
 
   System.out.println("Enter value to find");
   search = in.nextInt();
 
   for (c = 0; c < n; c++)
   {
     if (array[c] == search)     /* Searching element is present */
     {
        System.out.println(search + " is present at location " + (c + 1) + ".");
         break;
     }
  }
  if (c == n)  /* Searching element is absent */
     System.out.println(search + " is not present in array.");
}
}

Monday, December 2, 2002

S Y S T E M C O M M A N D S

package org.interview.test;

import java.net.InetAddress;
import java.util.Random;

public class SystemCommands {

public static void main (String [] args) throws Exception {
Runtime rt = Runtime.getRuntime();
//rt.exec("notepad");
//rt.exec("mspaint");

System.out.println("Free memory in JVM before Garbage Collection = "+rt.freeMemory());
   rt.gc();
   System.out.println("Free memory in JVM after Garbage Collection = "+rt.freeMemory());
     System.out.println(InetAddress.getLocalHost());
     
     int c;
     Random t = new Random();
  
     // random integers in [0, 100]
  
     for (c = 1; c <= 10; c++) {
       System.out.println(t.nextInt(100));
     }
     
}
}

P A L I N D R O M E

package org.interview.test;

import java.util.Scanner;

public class Palindrome {

public static void main(String [] args) throws Exception {
String original , reverse = "";
Scanner sc = new Scanner(System.in);
System.out.println("Enter:" );
original = sc.next();

int length = original.length();

System.out.println("Length:"+length);

for(int i =length-1; i >= 0; i--) {
reverse = reverse + original.charAt(i);
}

System.out.println("Reverse:"+ reverse);

if(original.equals(reverse)) {
System.out.println(original+" - is palindrome of - " + reverse);
}
}

}
= = = = = = = = = = = = = = = = = Reverse String recursive and iterative = = = = = = = = = = = = = = = = = = = = = 
package com.test;

import java.io.FileNotFoundException;
import java.io.IOException;

public class StringReverseExample {

    public static void main(String args[]) throws FileNotFoundException, IOException {

        //original string
        String str = "Sony is going to introduce Internet TV soon";
        System.out.println("Original String: " + str);

        //reversed string using Stringbuffer
        String reverseStr = new StringBuffer(str).reverse().toString();
        System.out.println("Reverse String in Java using StringBuffer: " + reverseStr);

        //iterative method to reverse String in Java
        reverseStr = reverse(str);
        System.out.println("Reverse String in Java using Iteration: " + reverseStr);

        //recursive method to reverse String in Java
        reverseStr = reverseRecursively(str);
        System.out.println("Reverse String in Java using Recursion: " + reverseStr);

    }

    public static String reverse(String str) {
        StringBuilder strBuilder = new StringBuilder();
        char[] strChars = str.toCharArray();

        for (int i = strChars.length - 1; i >= 0; i--) {
            strBuilder.append(strChars[i]);
        }

        return strBuilder.toString();
    }

    public static String reverseRecursively(String str) {

        //base case to handle one char string and empty string
        if (str.length() < 2) {
            return str;
        }

        return reverseRecursively(str.substring(1)) + str.charAt(0);

    }
}

P R I M E N U M B E R

package org.interview.test;

import java.util.ArrayList;
import java.util.List;

public class PrimeNumbers {


public static void main(String [] args) throws Exception {
PrimeNumbers pn = new PrimeNumbers();
int number =18;
List<Integer> l = new ArrayList<Integer>();
for(int i=2; i< number; i++){
if(pn.isPrime(i)) {
l.add(i);
}
}
System.out.println("IsPrime:" + l);


}


// Find prime number from a number.
public boolean isPrime(int number) {
for (int i=2; i< number; i++){
if(number%i == 0){
return false;
}
}
return true;
}

}

Largest Number

package org.interview.test;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class LargestNumber {

public static void main (String [] args ) throws Exception {

List<Integer> il = new ArrayList<Integer>();

Scanner sc = new Scanner(System.in);

int i;
do{
i  = sc.nextInt();
il.add(i);
} while (i != -1);
System.out.println("List:"+il);

for (int in : il) {
if (in > i)
i = in;
}

System.out.println("Largest Number:"+ i);


}
}

Floyd Triangle

package org.interview.test;

import java.util.Scanner;

public class FloydTriangle {

/*
*In Floyd triangle there are n integers in the nth row and a total of (n(n+1))/2 integers 
*in n rows. This is a simple pattern to print but helpful in learning how to create other 
*patterns. Key to develop pattern is using nested loops appropriately.
*/
public static void main (String [] args) throws Exception {
int n, num = 1, c, d;
     Scanner in = new Scanner(System.in);
 
     System.out.println("Enter the number of rows of floyd's triangle you want");
     n = in.nextInt();
 
     System.out.println("Floyd's triangle :-");
 
     for ( c = 1 ; c <= n ; c++ )
     {
        for ( d = 1 ; d <= c ; d++ )
        {
           System.out.print(num+" ");
           num++;
        }
 
        System.out.println();
     }
}
}

F A C T O R I A L

package org.interview.test;

import java.util.Scanner;

public class Factorial {

public static void main (String [] args) throws Exception {
findFactorial();
}

public static Integer findFactorial() {
 int n , fact = 1;
 
 Scanner sc = new Scanner(System.in);
 
 System.out.println("Enter number to calculate Factorial: ");
 n = sc.nextInt();
 
 for (int i = 1 ; i <= n ; i++) {
 fact *= i;
 }
 System.out.println("Factorial: " + fact);
 return fact;
}

}

C A L C U L A T O R

package org.interview.test;

import java.util.Scanner;

public class Calculator {

public static void main (String []  args) throws Exception {

Scanner sc = new Scanner(System.in);

System.out.println("First Number:");
int x = sc.nextInt();
System.out.println("Second Number:");
int y = sc.nextInt();

System.out.println("Mathematical Operation:");
String op = sc.next();

if(op.equalsIgnoreCase("/")) {
System.out.println(x/y);
}else if(op.equalsIgnoreCase("*")) {
System.out.println(x*y);
}else if(op.equalsIgnoreCase("+")) {
System.out.println(x+y);
}else if(op.equalsIgnoreCase("-")) {
System.out.println(x-y);
}else if(op.equalsIgnoreCase("eo")) {
if(x%2==0) {
System.out.print("X is Even");
} else {
System.out.println("X is Odd");
}
if(y%2==0) {
System.out.print("Y is Even");
} else {
System.out.println("Y is Odd");
}
}

}
}

Sunday, December 1, 2002

Bubble Sort

package org.interview.test;

import java.util.Scanner;

public class BubbleSort {

/**
* Complexity of bubble sort is O(n2) which makes it a less frequent option for 
* arranging in sorted order when quantity of numbers is high.
* @param args
*/
public static void main(String []args) {
   int n, c, d, swap;
   Scanner in = new Scanner(System.in);
 
   System.out.println("Input number of integers to sort");
   n = in.nextInt();
 
   int array[] = new int[n];
 
   System.out.println("Enter " + n + " integers");
 
   for (c = 0; c < n; c++) 
     array[c] = in.nextInt();
 
   for (c = 0; c < ( n - 1 ); c++) {
     for (d = 0; d < n - c - 1; d++) {
       if (array[d] > array[d+1]) /* For descending order use < */
       {
         swap       = array[d];
         array[d]   = array[d+1];
         array[d+1] = swap;
       }
     }
   }
 
   System.out.println("Sorted list of numbers");
 
   for (c = 0; c < n; c++) 
     System.out.println(array[c]);
 }

}

Binary Search

package org.interview.test;

import java.util.Arrays;
import java.util.Scanner;

public class BinarySearch {

public static void main (String [] args) throws Exception {
binarySearch();

binarySearch02();
}



public static void binarySearch02(){


int c, first, last, middle, n, search, array[];
 
   Scanner in = new Scanner(System.in);
   System.out.println("Enter number of elements");
   n = in.nextInt(); 
   array = new int[n];
 
   System.out.println("Enter " + n + " integers");
 
 
   for (c = 0; c < n; c++)
     array[c] = in.nextInt();
 
   System.out.println("Enter value to find");
   search = in.nextInt();
 
   first  = 0;
   last   = n - 1;
   middle = (first + last)/2;
 
   while( first <= last )
   {
     if ( array[middle] < search )
       first = middle + 1;    
     else if ( array[middle] == search ) 
     {
       System.out.println(search + " found at location " + (middle + 1) + ".");
       break;
     }
     else
        last = middle - 1;
 
     middle = (first + last)/2;
  }
  if ( first > last )
     System.out.println(search + " is not present in the list.\n");
  
  
}

/**
* binarySearch method returns the location if a match occurs otherwise -(x+1) 
* where x is the no. of elements in the array, For example in the second case 
* above when p is not present in characters array the returned value will be -6.
*/
public static void binarySearch (){
char characters[] = { 'a', 'b', 'c', 'd', 'e' };
 
   System.out.println(Arrays.binarySearch(characters, 'a'));
   System.out.println(Arrays.binarySearch(characters, 'c'));
   System.out.println(Arrays.binarySearch(characters, 'p'));
}
}

Armstrong Number

package org.interview.test;

import java.util.Scanner;

public class ArmstrongNumber {

/*
* An Armstrong number of three digits is an integer such that the sum of the cubes of its 
*  digits is equal to the number itself. 
* For example, 371 is an Armstrong number since 3**3 + 7**3 + 1**3 = 371.
*/
public static void main (String [] args ) throws Exception {
int n, sum = 0, temp, r;
 
     Scanner in = new Scanner(System.in);
     System.out.println("Enter a number to check if it is an armstrong number");      
     n = in.nextInt();
 
     temp = n;
     System.out.println("temp:"+temp);
     int c =1;
     while( temp != 0 ) {
     System.out.println(c+".temp:"+temp);
        r = temp%10;
        System.out.println(c+".r:"+r);
        sum = sum + r*r*r;
        System.out.println(c+".sum:"+sum);
        temp = temp/10; 
        System.out.println(c+".temp:"+temp);
        c++;
     }
 
     if ( n == sum )
        System.out.println("Entered number is an armstrong number.");
     else
        System.out.println("Entered number is not an armstrong number.");
}

}

Add Matrix

package org.interview.test;

import java.util.Scanner;

public class AddMatrix {
public static void main(String args[])
  {
     int m, n, c, d;
     Scanner in = new Scanner(System.in);
 
     System.out.println("Enter the number of rows and columns of matrix");
     m = in.nextInt();
     n  = in.nextInt();
 
     int first[][] = new int[m][n];
     int second[][] = new int[m][n];
     int sum[][] = new int[m][n];
 
     System.out.println("Enter the elements of first matrix");
 
     for (  c = 0 ; c < m ; c++ )
        for ( d = 0 ; d < n ; d++ )
           first[c][d] = in.nextInt();
 
     System.out.println("Enter the elements of second matrix");
 
     for ( c = 0 ; c < m ; c++ )
        for ( d = 0 ; d < n ; d++ )
           second[c][d] = in.nextInt();
 
     for ( c = 0 ; c < m ; c++ )
        for ( d = 0 ; d < n ; d++ )
            sum[c][d] = first[c][d] + second[c][d];  //replace '+' with '-' to subtract matrices
 
     System.out.println("Sum of entered matrices:-");
 
     for ( c = 0 ; c < m ; c++ )
     {
        for ( d = 0 ; d < n ; d++ )
           System.out.print(sum[c][d]+"\t");
 
        System.out.println();
     }
  }
}