Distributing AND over OR in a binary tree (Conjunctive Normal Form)

后端 未结 2 1133
忘了有多久
忘了有多久 2021-01-14 01:08

I\'m trying to convert a binary tree e.g.

OR (Implementation of Operator - a specialisation of TreeNode... see below)
|-A (Implementation of TreeNode... see          


        
2条回答
  •  鱼传尺愫
    2021-01-14 01:55

    I recommend you look how the tree is navigated, in your code looks like is a Depth-first search so you will start with the deepest branch (Deepest operator) you have to design your method distribute expecting that order and apply the Distributive Laws for the child nodes in a backtracking way.

    A very general description of what distribute method should do is:

    The flow of what kind of distributive law have to be applied depends on parent's operation type and child nodes. Each child node can be an operator or a value, depending on this combination do the distribution required by the law.

    A pseudo code of what i am trying to tell you is:

    if parent node is OR type
        if child nodes are OPERATOR-VALUE combination
            if OPERATION is AND type
                apply correspondig distribution 
                return the new parent
            else
                apply correspondig distribution 
                return the new parent
        if child node are VALUE-VALUE combination
            return parent
    if parent node is AND type
        if child nodes are OPERATOR-VALUE combination
            if OPERATION is AND type
                apply correspondig distribution 
                return the new parent
            else
                apply correspondig distribution 
                return the new parent
        if child nodes are VALUE-VALUE combination
            return parent;
    

    An implementation example:

    public TreeNode distribute(TreeNode parent,TreeNode leftChild, TreeNode rightChild) {
        if( !(leftChild instanceof Operator) && !(rightChild instanceof Operator) ){
            /*There is nothing to do */
            return parent;
        }
        if( parent.getType() == 'OR'){
            /*
                Apply distributive laws and return the new branch
                for example:        
            */
            if ( (leftChild instanceof operator) &&  !(rightChild instanceof Operator) ){
                TreeNode operatorLeftChild  = leftChild.getLeftChild();
                TreeNode operatorRightChild = leftChild.getRightChild();
                if(leftChild.getType() == 'AND' )
                {
                    /*
                    Applying distributive laws:
                        rightChild OR (operatorLeftChild AND operatorRightChild) 
                            -> (rightChild OR operatorLeftChild) AND (rightChild OR operatorRightChild)
                    */
                    TreeNode newBranch = new Operator("AND");
                    /*new Left child*/
                    TreeNode newLeftChild= new Operator("OR");
                    newLeftChild.setLeftChild(rightChild);
                    newLeftChild.setRightChild(operatorLeftChild);
                    /*new Richt Child */
                    TreeNode newRightChild= new Operator("OR");
                    newRightChild.setLeftChild(rightChild);
                    newRightChild.setRightChild(operatorRightChild);
                    /*Setting the new Branch*/
                    newBranch.setLeftChild(newLeftChild);
                    newBranch.setRightChild(newRightChild);
                    return newBranch;
                }
    
            }
        }
        if( parent.getType() == 'AND'){
            /*
                Else-If and distributive laws stuff
            */
        }
        /*
            You can also implement this part wihtout the else-if code by implementing a true table
            but is more abstract and less human redeable
         */
    }
    

    Note The previous code has not been tested and i am assuming a lot of things i dont know how your tree is implemented may be you will be required to update the parent reference in child nodes.

提交回复
热议问题