Basically, an N-array tree is such a tree structure in which each node can have a max of up to āNā number of children. The largest independent set is a set of vertices in which no two vertexes are adjacent to each other. So basically in this program, we have to see that how can we find the size of such a largest set in the N-array tree. Here we are implementing the tree using a vector in java and its idea of adjacency list from the graph theory is used.Ā
The algorithm goes as:
What mainly we are going to do is that we will create a LIS(int a) method to which the number of the current node is passed. This is a recursive method. In this method, we will check the base conditions first. Before discussing the base conditions, we have to first see the rest part of the method.Ā
So in the code, for each node, we mainly see that whether including that node inset gives the larger set or not. If not then that particular node is not included but since this node is not included, so we have to repeat the same process for its children. But if the node is included then we cannot include its children, so we have to check for its grandchildren the same thing ad done for the parent, and in this way we can get to know whether to include this node or not.
Now coming to the base cases:Ā
- If the node is null, which means the node does not exist then we cannot include anything.
- If the node is a leaf then we must include it.
Why to always include those nodes which are leaf node, when method is called upon them?
The main part to think here is that some node may be passed to this method only if its parent are not included in the set except the root one. So if parents are not there in set and this node is leaf one then we should include this node in the set. This is basically a greedy approach.
We will also be making a small change in our code to print the set elements also.
Java
// Java Program to Find Size of the Largest Independent // Set(LIS) in a Given an N-array Tree import java.io.*; import java.util.*; Ā
// save the file named as GFG2.java public class GFG2 { Ā Ā Ā Ā Ā Ā Ā // declaring static list of vector. Ā Ā Ā Ā public static Vector<Vector<Integer> > v Ā Ā Ā Ā Ā Ā Ā Ā = new Vector<Vector<Integer> >(); Ā Ā Ā Ā Ā Ā Ā // 7 nodes initially Ā Ā Ā Ā public static int n = 7 ; Ā Ā Ā Ā public static void main(String[] args) Ā Ā Ā Ā { Ā Ā Ā Ā Ā Ā Ā Ā System.out.println( "Initializing an n array tree" ); Ā
Ā Ā Ā Ā Ā Ā Ā Ā Vector<Integer> v0 = new Vector<Integer>(); Ā Ā Ā Ā Ā Ā Ā Ā v0.add( 1 ); Ā Ā Ā Ā Ā Ā Ā Ā v0.add( 2 ); Ā Ā Ā Ā Ā Ā Ā Ā v.add(v0); Ā Ā Ā Ā Ā Ā Ā Ā Vector<Integer> v1 = new Vector<Integer>(); Ā Ā Ā Ā Ā Ā Ā Ā v1.add( 3 ); Ā Ā Ā Ā Ā Ā Ā Ā v1.add( 4 ); Ā Ā Ā Ā Ā Ā Ā Ā v.add(v1); Ā Ā Ā Ā Ā Ā Ā Ā Vector<Integer> v2 = new Vector<Integer>(); Ā Ā Ā Ā Ā Ā Ā Ā v2.add( 5 ); Ā Ā Ā Ā Ā Ā Ā Ā v.add(v2); Ā Ā Ā Ā Ā Ā Ā Ā Vector<Integer> v3 = new Vector<Integer>(); Ā Ā Ā Ā Ā Ā Ā Ā v3.add( 6 ); Ā Ā Ā Ā Ā Ā Ā Ā v.add(v3); Ā Ā Ā Ā Ā Ā Ā Ā Vector<Integer> v4 = new Vector<Integer>(); Ā Ā Ā Ā Ā Ā Ā Ā v.add(v4); Ā Ā Ā Ā Ā Ā Ā Ā v.add(v4); Ā Ā Ā Ā Ā Ā Ā Ā v.add(v4); Ā
Ā Ā Ā Ā Ā Ā Ā Ā /* Ā Ā Ā Ā Ā Ā Ā Ā the tree looks like Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā 0 Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā /Ā Ā Ā Ā Ā Ā Ā \ Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā 1Ā Ā Ā Ā Ā Ā Ā 2 Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā /\Ā Ā Ā Ā Ā Ā / Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā 3Ā 4Ā Ā Ā Ā Ā 5 Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā / Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā 6 Ā Ā Ā Ā Ā Ā Ā Ā so initially the vector looks like Ā Ā Ā Ā Ā Ā Ā Ā v = { Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā {1,2}, Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā {3,4}, Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā {5}, Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā {6}, Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā {}, Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā {}, Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā {}, Ā Ā Ā Ā Ā Ā Ā Ā } Ā Ā Ā Ā Ā Ā Ā Ā */ Ā
Ā Ā Ā Ā Ā Ā Ā Ā System.out.println( Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā "Finding the elements to be included in the set" ); Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā // calling the function with the first node. Ā Ā Ā Ā Ā Ā Ā Ā int x = LIS( 0 ); Ā Ā Ā Ā Ā Ā Ā Ā System.out.println( "process finished and size is " Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā + x); Ā Ā Ā Ā } Ā
Ā Ā Ā Ā public static int LIS( int a) Ā Ā Ā Ā { Ā Ā Ā Ā Ā Ā Ā Ā // if no node is there with labelling a Ā Ā Ā Ā Ā Ā Ā Ā if (a >= n) Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā return 0 ; Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā // if it is leaf node Ā Ā Ā Ā Ā Ā Ā Ā if (v.get(a).size() == 0 ) { Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā System.out.println(a); Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā return 1 ; Ā Ā Ā Ā Ā Ā Ā Ā } Ā Ā Ā Ā Ā Ā Ā Ā // if not considering that node Ā Ā Ā Ā Ā Ā Ā Ā int ifno = 0 ; Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā // if considering that node. Ā Ā Ā Ā Ā Ā Ā Ā int ifyes = 1 ; Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā // since not considering this node Ā Ā Ā Ā Ā Ā Ā Ā // so we should call the same function Ā Ā Ā Ā Ā Ā Ā Ā // on the children of this node Ā Ā Ā Ā Ā Ā Ā Ā for ( int i = 0 ; i < v.get(a).size(); ++i) Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā ifno += LIS(v.get(a).get(i)); Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā // if including this node Ā Ā Ā Ā Ā Ā Ā Ā // then call the same function recursively on the Ā Ā Ā Ā Ā Ā Ā Ā // grand children of this node. Ā Ā Ā Ā Ā Ā Ā Ā for ( int i = 0 ; i < v.get(a).size(); ++i) { Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā int k = v.get(v.get(a).get(i)).size(); Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā --k; Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā while (k >= 0 ) { Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā ifyes += LIS(v.get(v.get(a).get(i)).get(k)); Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā --k; Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā } Ā Ā Ā Ā Ā Ā Ā Ā } Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā // if found that including this node is beneficial Ā Ā Ā Ā Ā Ā Ā Ā if (ifyes > ifno) Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā System.out.println(a); Ā Ā Ā Ā Ā Ā Ā Ā return Math.max(ifyes, ifno); Ā Ā Ā Ā } } |
Ā
Ā
Initializing an n array tree Finding the elements to be included in the set 6 4 6 5 4 6 5 0 process finished and size is 4
Since the output shows the elements of the set more than once, so we have to basically implement a map or a set datatype to get the elements uniquely.
Second thing to note is that this method is recursive approach so this can lead to exponential time complexity. This method can be enhanced using DP approach. We can achieve memorization through map data structure.
Ā