Coding Challenge Day- 29: Problem 1: Array representation of complete Binary Tree

Hello! So I’m doing a 30 day coding challenge where I solve a few questions every day and thought of posting them here on my blog so that you guys can join the challenge too!

Welcome to Coding challenge Day 29: Problem 1! Be sure to post your answers, queries etc in the comments!

Problem: Array representation of complete Binary Tree

Sample:

Output: 1 2 3 4 5 6 7

Solution:

Inorder to understand the concept of binary tree array representation you can watch the first few minutes of this video:

package binary_tree;

public class Array_representation_runner {

	public static void main (String [] args){
		
		/*             1
		 *           /    \
		 *         2       3
		 *        / \     /  \
		 *       4   5    6   7
		 */
			
			/* if a node is at index i and root at index 0
			 * it's left child is at 2*i +1
			 * it's right child is at 2*i+2
			 * it's parent is at i/2
			 * 
			 */
		Array_representation obj= new Array_representation();
		obj.Root("1");
		obj.add_left("1", "2");
		obj.add_right("1", "3");
		obj.add_left("2", "4");
		obj.add_right("2", "5");
		obj.add_left("3", "6");
		obj.add_right("3", "7");
		
		obj.display_tree();
		
		}
}

public class Array_representation {
	
	String [] tree= new String[7];
	
	public void Root (String root){
		tree[0]=root;
	}
	
	public Integer find_parent_index(String parent){
		Integer parent_index=null;
		for(int i=0; i<tree.length; i++){
			if (parent.equals(tree[i])){
				parent_index=i;
			}
		}
		return parent_index;
	}
	
	public void add_left(String parent_node, String node){
		Integer parent_index= find_parent_index(parent_node);
		tree[parent_index*2+1]= node;
	}
	
	public void add_right(String parent_node, String node){
		Integer parent_index= find_parent_index(parent_node);
		tree[parent_index*2+2]= node;
	}
	
	public void display_tree(){
		for(int i=0; i<tree.length; i++){
			System.out.print(tree[i] + " ");
		}
	}
	
	

}



Download Code

Happy Learning!!

Leave a Reply

PHP JS HTML CSS BASH PYTHON CODE

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

%d bloggers like this:
search previous next tag category expand menu location phone mail time cart zoom edit close