Posts

Showing posts from April, 2013

Fetching Documents from remote address in PHP

We can get information uploaded from the remote client system using PHP script below HTML  <form enctype="multipart/form-data"   action="upload.php"   method="post"> <input type="file" name="ufile"> <input type="submit" value="submit"> PHP script <?php  $fdir="C:/xampp/htdocs/mysite/uploads"; $furl="http://localhost/mysite/uploads"; echo $ufile; print "$fdir/$ufile_name"; copy($ufile,"$fdir/$ufile_name"); print "copied <br><img src='$furl/$ufile_name'>"; ?> Also See   How to upload file on server using PHP

Array functions in PHP

There are many array functions in PHP which can be used to manipulate the array elements. Some of them can be used directly on the array elements such that you don't have to write code for it. Though there are a lot of array functions I will write some of the important ones. 1) in_array() function: in_array function is used to check whether the element is present in an array or not if it is present then it will return true otherwise false. example : <?php $starwars=array("princess"=>"leia","teacher"=>"Yoda","bad guy"=>"Darth"); echo in-array("Darth",$starwars);       // returns true echo in_array("obi-san",$starwars);    //returns false ?> 2) array_search() function : array_search function is used to search an array for given value and returns its corresponding key. example: <?php $sort=array("Bubble"=>"sort1","Selection"=>"sor...

Program to find the Equilibrium index of an array

Equilibrium index of an array is the index such that the sum of its lower index values and the sum of its higher index values are same. Suppose the array values are a[0] =1  a[1] =-5   a[2] =4   a[3] =4   a[4] =-6   a[5] =5   a[6] =1 then the index 3 will be at Equilibrium because a[0]+a[1]+a[2]=a[4]+a[5]+a[6]. In an array there can be more then one Equilibrium indexes provided the sum of its lower indexes and higher indexes are same. The logic of the program is pretty simple.First we will calculate the sum of the whole array elements and then initialize leftsum=0.Now we iterate through all the index of the arrays and substract all index values from the sum and add to leftsum and simultaneously check whether sum=leftsum.If it is found out equal then return i that is the index of the array. Program : #include <stdio.h> #include<conio.h> int equilibrium(int arr[], int len) {    int sum = 0;        in...

Find two element in an array whose sum is closest to zero

The array is having both +ve and -ve values.Lets take array values as  3 -7 8 9 5 -3 Then the two numbers with sum closest to zero will be 3 and -3. Program : # include <stdio.h> # include <stdlib.h> # include <math.h> void sumclosetozero(int arr[], int size) {   int count = 0;   int a, b, sum_min, sum, a_min, b_min;   a_min = 0;   b_min = 1;   sum_min = arr[0] + arr[1];   for(a = 0; a < size - 1; a++)   {     for(b = a+1; b < size; b++)     {       sum = arr[a] + arr[b];       if(abs(sum_min) > abs(sum))       {         sum_min = sum;         a_min = a;         b_min = b;       }     }   }   printf(" The two elements whose sum is minimum are %d and %d",           arr[a_min], arr[b_min]); } int ma...

The Pigpen/Masonic Cipher

Image
Pigpen cipher is used by freemasons in 18th century.For that reason it is also called as masonic cipher.It is different from other ciphers as a fact that it does not substitute another letter in place of letter like other ciphers rather it uses symbols substituted in place of letters.Each of the 26 letters have different symbols.The freemasons actually made four different structures with letters embed in them and used part of that structure as a symbol of that particular letter. So for A they used   __| B they used    |__| for J      __.|  for S     \ / for W   \./ It is also named as rosicrucian cipher as it is believed that variations of ciphers was used by Rosicrucians  brotherhood along with freemasons.The pigpen cipher is used in Dan brown Novel "The lost symbol".It is also used in the game "Assassins creed II".It was also published in the website  The Science of Deduction  created by Sherlock series BBC a...

Ant in a Maze problem

Image
Ant in a maze is another problem that can be solved using backtracking algorithm.In this problem there is a NxN  maze in which one corner of maze is entry point and other is exit point.Now there is an ant in a maze who wants to go from entry to exit.For doing this there are certain constraints like an ant can move only forward or downward but no backward and upward.For the sake of simplicity we are taking 4x4 Maze.The maze can be denoted by a matrix with values 0 and 1.0 means the path is blocked and 1 means the path is available.The maze and the path for ant from entry to exit is The block which are in grey color are dead end in the maze that is the ant cannot go through such blocks.The red path is the path travelled by ant from entry to exit.The matrix representation of the above maze without the path will be (input to be taken) maze[4][4]={{1,1,0,0}, {1,1,0,1}, {0,1,0,0}, {1,1,1,1} } and the matrix representation of path travelled by ant will be (output t...

Functions declarations which cannot be overloaded

Generally there is a confusion among students regarding the function overloading.So it is an important part to be covered for interviews.Companies often asked function overloading questions which are generally tricky and confuse students.So here are some functions which cannot be overloaded in C++. 1) Function declaration that differ only in return type cannot be overloaded. 2) Member function with the same name and the parameter list cannot be overloaded if any of them is static member function declaration. ex : static void func(int i)                void func(int i) 3) Parameter declaration that differ only in a pointer (*) versus an array [] are equivalent and hence cannot be overloaded. ex : int func(int *p)       int func(int p[]) 4) The function declaration with parameter having const keyword is equivalent to normal parameter declaration hence cannot be overloaded. ex : int func(int x)       in...

Program to convert Binary tree to Doubly linked list

Image
The order of Doubly linked list will be same as the inorder of the Binary tree.So the first node of DLL will be the leftmost node of Binary tree.Let us assume that the given Binary tree is Now the order of the Doubly linked list will be 31 23 36 15 42 34. Algorithm : The algorithm of this program is pretty simple.We will first find the inorder of the left subtree and convert into DLL.Then we again find the inorder of right subtree and convert into DLL.Then finally we join both DLL to the root node of the tree. 1) Recursively convert left subtree to DLL 2) Now find the inorder predecessor of root node. Inorder predecessor is the right most node of left subtree.Let take it as IP node. 3) Now nake root node as next of IP node and IP node as previous of root node. 4) Recursively convert Right subtree to DLL 5) Now find the inorder successor of root node.The inorder successor of root node is the left node of right subtree.Let take it as IS node. 6) Now make IS node next of...

Program to find the maximum Height of a Binary Tree

Maximum Height of binary tree is the maximum number of nodes between the root node and the farthest leaf node which could be in either left or right subtree of Binary tree. Program : #include<stdio.h> #include<stdlib.h> #include<conio.h> struct node {     int data;     struct node* left;     struct node* right; }; int maxheight(struct node* node) {    if (node==NULL)        return 0;    else    {              int l = maxheight(node->left);        /*Recursively travel till you reach the farthest node on left        int r = maxheight(node->right);     /*Recursively travel till you reach the farthest node on Right        if (l>r)            return(l+1);                   ...

Register keyword in C

The variables which are most frequently used in a program can be put in registers using 'register' keyword  because register are faster than memory to access..The keyword 'register' tells compiler to store the variable in register instead of memory.Its compiler choice to put it in register or not.But mostly when compiler do optimizations then they put the variables in registers. When we store variables in a register and not in memory we cannot use & operator with variables because we cannot access the address of register.Using & operator with register variable will throw error by the compiler. int main() { register int j=10; int *p=&j; printf("%d",*p); getch(); } The above program will throw error as we are accessing address of register variable j.Now suppose we make pointer variable register instead of j what will happen now? will program run successfully or throw error? int main() { int j=10; register int *p=&j; printf(...

How to Create Project in Django Python Framework

Installation and setup of python and Django Django is a Python framework that is used to make python projects and web applications easily.It works for any python version. It supports a database called SQLite and you don't have to set up the database. For using Django you first need to install python. You can get python @  http://www.python.org .After installing python you can check whether Python is installed or not by typing python command in cmd, and if python is installed you will see the python version in the command line. After that, you can install Django's latest version and start making python projects. For the installation of Django you can refer  https://docs.djangoproject.com .Now if you are done with installing python and Django you can check the version of Django you installed by typing and running the command   python -c "import django;print(django.get_version())" Creating a project in Django Change your current directory where you want to s...

Heaven Dream Riddle

Riddle : A man saw in a dream that he died and went to the heaven.In heaven he saw thousands of people roaming whom he dont know.All of the people were naked.Suddenly he saw two couples moving around and he recognized them.He knew that these couples are Adam and Eve.How would he so sure that the couple he saw was adam and eve (obviously he never met adam and eve before)? Solution : He immediately recognized adam and eve because he saw the couples who dont have navel.Obviously those two were not born of women so they dont had umbilical cord and therefore never had navel.

Password riddle

Riddle : Steve works in cryptology department.One fine morning when steve entered his room in office he saw that his system is already logged in and all his important files are gone .Steve then went to his boss cabin and said "I need my system to be secure for that i need new password.My old password is hacked and all my important files are gone". Boss told him "I know your important files are gone and for that i issued you new password.Your new password is unbreakable,trust me". Steve said "But what is my new password?" Boss said "This is important.If you will listen carefully you will get your new password.Your new password is in someway opposite to your old password and you already heard that.Your new password and old password has 3 letters in common and your new password length is one less then the double of your old password length.Always remember more the length of password more it is difficult to crack." Steve then went to his ...

Water cans puzzle

Water cans puzzle is very common puzzle asked in interviews.somewhere or the other you must have encountered with this type of puzzles. Puzzle : Sam is on a treasure hunt and on his way to find out the treasure he reached at river where he encountered with the next clue which will further show him the path towards the treasure.Now for the next clue he saw two cans,one is of 9 gallon and another is of 4 gallon both are empty initially and a balance with a note on it "Exactly six gallons of water will show you the way".Now Sam has to measure exactly six gallons of water to get the map for further search.Assume that Sam can transfer water from one can to another and also throw water if it is required.How will he measure exactly 6 gallons of water? Solution : Obviously you cannot measure 6 gallons of water in a 4 gallon can.So you have to take 6 gallons of water in a 9 gallon can and keep it on balance. Here are the steps sam will follow :- 1) Sam will first pour wat...

Program for union of two linked lists

Union of two linked list will give the distinct elements of both the linked list. List 1 : 4->8->9->30->5 List 2 : 6->4->9->32->7 Union : 4->8->9->30->5->6->32->7 The logic for program of union of two linked list is very simple.Take the resultant linked list and initialize it to NULL.Now traverse list 1 till the null and insert all the values in resultant linked list.Now take list 2 and check whether the value of list 2 is already present in resultant linked list.If the value is not present in the linked list then insert it otherwise move forward without inserting. Program : struct node { int data; node* next; } void insert(node** head,int value) { node* temp; temp=(node*)malloc(sizeof(node)); temp->data=value; temp->next=head; head=temp; } bool present(node* head,int data) { node* temp; temp=(node*)malloc(sizeof(node)); while(temp!=NULL) { if(temp->data==data) return 1; temp=temp->next; } retur...

8 Queens Problem

Image
8 Queen problem is a problem in which we have to place 8 Queens on 8x8 chessboard such that no two Queens attack each other.For placing the queens Backtrack Algorithm is used.Let us know first what is backtrack algorithm. Backtrack Algorithm : Backtrack algorithms uses a incremental technique to arrive at a final solution.It will take the candidate as valid and check all the constraints,if the solution is possible then it moves forward or else it will abandons it when it determines that solution is not possible taking the present candidate. How backtracking is helpful in the case of 8 Queens problem?? We will be going to place all the Queens in columns one by one from the leftmost column.When we will be placing the queens in the column we will check the constraints like if there is another queen in the row or column or diagonally.If we find a row that is valid and we can place a queen in that then we will take that row and column as a part of the solution.But if we cannot find s...

Program to Rotate a linked list by k nodes

Lets take linked list as 10->30->60->90->20->40 and we want to rotate it by k=4 nodes.That means we want to rotate from (k+1)th node.The final linked list after rotation will be like 20->40->10->30->60->90. The basic idea to do that is make the kth node as NULL and the last node will point to the head node.So here is the function of rotating the linked list by k nodes. Program : struct node {     int data;     struct node* next; }; // This function rotates a linked list counter-clockwise by k nodes and update head. void rotate (struct node **head, int k) {      if (k == 0)        return;         struct node* current = *head;     // current will either point to kth or NULL after this loop.         int count = 1;     while (count < k && current != NULL)     {         current = c...

How to make a simple GUI in Matlab

Image
Recently i was working on project which was to be done on Matlab and we have to present our analysis in Matlab.For that i need to make some kind of User Interface.After searching on internet for some time i found out about GUIDE in matlab for making basic GUI in Matlab.In this post i will tell you how to make a simple GUI in Matlab using GUIDE. To start with type Guide in your command line window.You will get window opened in which there is a tab create New GUI under which there will be 4 options Blank GUI GUI with UI Controls GUI with Axis and Menu Modal Question Dialog /* User interface (.fig file) */ Select Blank GUI to make your user interface.You can select other three options also to fit your needs.But in this post i will be using Blank GUI for making simple User Interface.After selecting, a Window will get opened where a palette with all the UI components is there.You can drag and drop it and place anywhere you want. I will make a simple GUI with two Edi...

Mango apples and bag labels

You have three bags and three labels. One bag has only Mangoes, one has only Apples and one has both Mangoes and Apples. Three labels are M, A and MA. M label was meant for the bag with only Mangoes, A label was meant for the bag with only Apples and MA for the bag with both Mangoes and Apples. Victor by mistake labelled the bags wrongly such that all the labels are wrong, how many minimum number of Fruits he should pick and from what bags to correct the labels? It is given that each bag has unlimited number of Fruits to be picked. Solution : The minimum number of Fruits Victor should pick to identify correct labels is 1 from the bag with label MA How just 1 ball ? As the label of all the bags are wrong, bag with label MA can either have all Mangoes or all Apples. Now Victor will either get Mango or the Apple. Case 1: Lets assume Victor gets Mango Bag with label MA is the bag with all the Mangoes. So now MA is M. Bag with label A can either be MA or M(as all the label...

Program to separate Even and Odd numbers in a linked list

struct node {   int data;   struct node *next; };   void separateEvenOdd(struct node **head_ref) {   struct node *end = *head_ref;     struct node *prev = NULL;   struct node *curr = *head_ref;     while(end->next != NULL)        end = end->next;     struct node *new_end = end;     /* Take all odd nodes before the first even node      and move then after end */  while(curr->data %2 != 0 && curr != end)   {     new_end->next = curr;     curr = curr->next;     new_end->next->next = NULL;     new_end = new_end->next;   }         /* Do following steps only if there is any even node */   if (curr->data%2 == 0)   {       *head_ref = curr;           /* now current points to the first even node */ ...