Skip to main content

Insertion Sort


  Insertion sort is like picking a card from a set of unsorted cards and comparing it
  to all the cards present on the left for higher or smaller values and inserting this
  card into right position. After every pass, the picked value reaches at its right position.
 
  for e.g.
  input : 10,5,3,4,12,1,13
  after First Pass :
  -> 5,10,3,4,12,1,13
  after Second Pass:
  -> 3,5,10,4,12,1,13
  after Third Pass:
  -> 3,4,5,10,12,1,13
  in fourth pass when the pointer is pointing to 12 there is not need to move it since
  it is already greater than the immediate next element i.e. 10:
  -> 3,4,5,10,12,1,13
  after fifth Pass:
  -> 1,3,4,5,10,12,13
  in sixth pass also there is no need to move the elements
  and you get your output
 
  It's time complexity is O(n^2) but still it performance much faster than bubble sort and
  slightly better than selection sort.
 
  Below is the code for same.


public class InsertionSort {

public static void main(String[] args) {
int[] arr = {10,5,3,4,12,1,13,2,50,1,11,6,9,0,12,3,87,27};
int temp = 0;
int k=0;
for(int i=1;i< arr.length;i++){
k= i-1;
if(arr[k]>arr[i]){
temp = arr[i];
while(k>=0 && arr[k]> temp){
arr[k+1] = arr[k];
k--;
}
arr[k+1] = temp;
}

}
for(int i=0;i<arr.length;i++){
System.out.print(arr[i]+" ");
}
}

}










Comments

Popular posts from this blog

Carnivorous Island from "Life of PI"

Yann Martel described about an floating carnivorous Island for symbolizing that something seemingly good in life can turn out to be harmful, so we should keep going with our journey of life... About the carnivorous Island from movie. In the movie 'Life of PI' after PI struggles to live in the pacific with the Bengal tiger suddenly one morning Pi  found himself at a Island. After spending so many days in the middle of the sea he found himself very lucky to find a Island. After spending some time he thought might be this was the end of his suffering and he can spend rest of his life at that island. He makes h is bed on a tree and sleeps there, in the middle of the night he wakes up and find that there were dead fish in the fresh water where he took swim in the day time. While trying to understand the mystery he plucks a fruit from the same tree and peel it off and finds a human tooth inside that fruit and then he realize that it was an carnivorous Island. The...

Create Table in Liquibase

For creating table using liquibase you can use below code and add it in your liquibase file. <createTable tableName=“employee”>      <column name="id" type="int">      <constraints primaryKey="true" nullable="false"/>   </column>      <column name="first_name" type="varchar(255)"/>   <column name="last_name" type="varchar(255)"/>   <column name="username" type="varchar(255)">      <constraints unique="true" nullable="false"/>   </column> </createTable> The use is pretty simple it's the way it looks : Tag: <createTable></createTable> This is an opening/ending tag for creating a table. These tags will enclose column sub tags which will define columns for the table. Attribute:   tableName : Name of the table which you want to create. (This is a mandatory   ...

liquibase.exception.LockException: Could not acquire change log lock. Currently locked by...

liquibase.exception.LockException: Could not acquire change log lock. Currently locked by... Solution : Open your database and find the table named 'Databasechangeloglock', check the content of the Locked column. If it is set to '1' in that case the above exception will be thrown. Try setting it to '0' and set content of the 'LOCKGRANT' and 'LOCKEDBY' to (null). You might find this interesting. http://apdynamicviews.blogspot.in/2012/08/how-databasechangeloglock-and.html