Skip to main content

Form a nested tree from an array of objects in javascript

So there is array of objects of below format

let inputs = [
    {
      "id": "614344d9d9c21c0001e6af2e",
      "groupName": "Unassigned",
      "parentGroup": "null"
    },
    {
      "id": "614447da152f69c3c1d52f2e",
      "groupName": "P1",
      "parentGroup": "null"
    },
    {
      "id": "614447da152f69c3c1d52f38",
      "groupName": "K1",
      "parentGroup": "C1"
    },
    {
      "id": "614447da152f69c3c1d52f3e",
      "groupName": "A2",
      "parentGroup": "C2"
    },
    {
      "id": "614447da152f69c3c1d52f40",
      "groupName": "G1",
      "parentGroup": "P2"
    },
    {
      "id": "614447da152f69c3c1d52f46",
      "groupName": "F1",
      "parentGroup": "null"
    },
    {
      "id": "614447da152f69c3c1d52f30",
      "groupName": "P2",
      "parentGroup": "null"
    },
    {
      "id": "614447da152f69c3c1d52f36",
      "groupName": "C2",
      "parentGroup": "P1"
    },
    
    {
        "id": "614447da152f69c3c1d52f3c",
        "groupName": "A1",
        "parentGroup": "C2"
      },
      {
        "id": "614447da152f69c3c1d52f34",
        "groupName": "C1",
        "parentGroup": "P1"
      },
      {
        "id": "614447da152f69c3c1d52f32",
        "groupName": "P3",
        "parentGroup": "null"
      },
      {
        "id": "614447da152f69c3c1d52f3a",
        "groupName": "K2",
        "parentGroup": "C1"
      },
      {
        "id": "614447da152f69c3c1d52f42",
        "groupName": "GG1",
        "parentGroup": "G1"
      },
      {
        "id": "614447da152f69c3c1d52f44",
        "groupName": "GGG1",
        "parentGroup": "GG1"
      }
  ]

i am trying to create a tree structure of format

{name:'p1',children:[{name:'c1':children:[]}]}

so i sorted all the elements of given array considering element with parentGroup as "null" to be at the top of the array.

 let finalArr = [];
 inputs.sort((a,b)=> (a.parentGroup === "null") ? -1 : 1);

And for each element of the inputs array, i was iterating below logic

inputs.forEach(ele => {
            if(ele.parentGroup === "null"){
             let child= {name:ele.groupName,children:[]};
             finalArr.push(child);
            }else{
              finalArr.forEach(item => {
                this.findNode(item,ele);
              })
            }
          });

If the 'parentGroup' of element is "null", then create a leaf kind of obj and push the element to 'finalArr' array

Else, then iterate across all the elements of 'finalArr' over a recursion function

public findNode(ele, obj){
    if(ele.children.length === 0){
      if(ele.name === obj.parentGroup){
        let child = {name:obj.groupName, children:[]};
      ele.children.push(child);
      }
    }else{
      let j = ele.children.length-1;
      this.findNode(ele.children[j--],obj);
    }
  }

This recursion function will check the element has children or not, if no children, then compare the parentGroup of given obj, with name of element from 'FinalArr'. if so ,push the current obj to the children of the element of finalArr.

else, that is, when children has more elements, the same recursion will be triggered until depth of the element is reached.

With this i tought i would make a tree structure with given inputs array, but when a parent has more children, of same level, this logic fails, so the inputs array has 'c1' which is a child of 'p1', but nly the child 'c2' resides, not sure the what is that i missed.

enter image description here

Via Active questions tagged javascript - Stack Overflow https://ift.tt/2FdjaAW

Comments

Popular posts from this blog

ValueError: X has 10 features, but LinearRegression is expecting 1 features as input

So, I am trying to predict the model but its throwing error like it has 10 features but it expacts only 1. So I am confused can anyone help me with it? more importantly its not working for me when my friend runs it. It works perfectly fine dose anyone know the reason about it? cv = KFold(n_splits = 10) all_loss = [] for i in range(9): # 1st for loop over polynomial orders poly_order = i X_train = make_polynomial(x, poly_order) loss_at_order = [] # initiate a set to collect loss for CV for train_index, test_index in cv.split(X_train): print('TRAIN:', train_index, 'TEST:', test_index) X_train_cv, X_test_cv = X_train[train_index], X_test[test_index] t_train_cv, t_test_cv = t[train_index], t[test_index] reg.fit(X_train_cv, t_train_cv) loss_at_order.append(np.mean((t_test_cv - reg.predict(X_test_cv))**2)) # collect loss at fold all_loss.append(np.mean(loss_at_order)) # collect loss at order plt.plot(np.log(al...

Sorting large arrays of big numeric stings

I was solving bigSorting() problem from hackerrank: Consider an array of numeric strings where each string is a positive number with anywhere from to digits. Sort the array's elements in non-decreasing, or ascending order of their integer values and return the sorted array. I know it works as follows: def bigSorting(unsorted): return sorted(unsorted, key=int) But I didnt guess this approach earlier. Initially I tried below: def bigSorting(unsorted): int_unsorted = [int(i) for i in unsorted] int_sorted = sorted(int_unsorted) return [str(i) for i in int_sorted] However, for some of the test cases, it was showing time limit exceeded. Why is it so? PS: I dont know exactly what those test cases were as hacker rank does not reveal all test cases. source https://stackoverflow.com/questions/73007397/sorting-large-arrays-of-big-numeric-stings

How to load Javascript with imported modules?

I am trying to import modules from tensorflowjs, and below is my code. test.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title </head> <body> <script src="https://cdn.jsdelivr.net/npm/@tensorflow/tfjs@2.0.0/dist/tf.min.js"></script> <script type="module" src="./test.js"></script> </body> </html> test.js import * as tf from "./node_modules/@tensorflow/tfjs"; import {loadGraphModel} from "./node_modules/@tensorflow/tfjs-converter"; const MODEL_URL = './model.json'; const model = await loadGraphModel(MODEL_URL); const cat = document.getElementById('cat'); model.execute(tf.browser.fromPixels(cat)); Besides, I run the server using python -m http.server in my command prompt(Windows 10), and this is the error prompt in the console log of my browser: Failed to loa...