bool has_gap(RightOrder &ro,
             const vector<double> &top_scores,
             OrderScoring &scoring)
{
    size_t p = ro.order.size();
    size_t n = ro.n;

    // Each node (position) has a value corresponding to the maximal score when that node is inserted somewhere in the sub order
    vector<int> indep_nodes;

    // PrintVector(ro.order);
    for (size_t node_index = 0; node_index < p - n; node_index++)
    {
        // Go though all of the unused nodes and inject them at second place (pos k)
        // of the sub order and at the very front of the order.
        int x = ro.order[node_index];
        RightOrder ro_bkp(ro);
        // Let say we have the sub order ([1,2,3,x],4,5), so 4 is the top.
        // Order score when x at very left (x,[1,2,3],4,5)
        double score_at_very_top = ro.order_score + top_scores[x];

        // Score order when x is inserted everywhere.
        vector<double> injected_order_scores;

        size_t top = p - n;
        size_t new_top = top - 1;

        make_visible(node_index, new_top, ro, scoring); // insert new node as new top.
        injected_order_scores.push_back(ro.order_score);

        // double max_rest_score = injected_order_scores[0];

        for (size_t i = 0; i < n; i++)
        {
            // compute order score when x is inserted at pos p-n-1,...,p-1 called 0,...,n.
            swap_nodes(new_top + i, new_top + i + 1, ro, scoring);
            injected_order_scores.push_back(ro.order_score); // TODO: The max of this should maybe be stored for optimel_front?

            if (definitelyLessThan(score_at_very_top, ro.order_score, EPSILON))
            {
                // If it is the top, we have to check:
                // 1. if it also is equal and if the top
                // 2. if the top is ordered.
                // These check are not needed when inserting at the other places.
                if (i == 0)
                {
                    // Maybe this should be in the for loop above??
                    // scoring ([1,2,3],4,x,5)
                    if (approximatelyEqual(score_at_very_top, injected_order_scores[1], EPSILON))
                    {
                        // if s(x,[1,2,3],4,5) == s([1,2,3],4,x,5)
                        // then check if s([1,2,3],x,4,5) == s([1,2,3],4,x,5)
                        // if so, prune if x > 4.
                        if (approximatelyEqual(injected_order_scores[0], injected_order_scores[1], EPSILON))
                        {
                            //([1,2,3],new_top,x,5)
                            if (ro.order[new_top] < ro.order[top])
                            {
                                // cout << "unorderd equal top"  << endl;
                                // cout << ro << ">" << ro_bkp << endl;
                                ro = ro_bkp;
                                return (true);
                            }
                        }
                    }
                }
                else
                {
                    // cout << "higher insert score"  << endl;
                    // cout << score_at_very_top << "<" << ro.order_score << endl;
                    // cout << ro << ">" << ro_bkp << endl;
                    ro = ro_bkp;
                    return (true); // Prune
                }
            }
        }

        // auto max_score = max_element(injected_order_scores.begin, injected_order_scores.end());
        // inserted_max_order_scores[ro.order[node_index]] = *max_score;
        ro = ro_bkp;
    }

    // ro.inserted_max_order_scores = inserted_max_order_scores;

    return (false);
}

