Untitled

 avatar
unknown
plain_text
a year ago
4.2 kB
3
Indexable
void assign( K const& keyBegin, K const& keyEnd, V const& val ) 
    {
        // if map empty 
                //if !(val == m_valBegin)
                    //assign (keyBegin, val) and (keyEnd, m_valBegin)
        if (m_map.empty())
        {
            if (!(val == m_valBegin))
            {
                //m_map[keyBegin] = val;
                //m_map[keyEnd] = m_valBegin;
                m_map.insert_or_assign(keyBegin, val);                
                m_map.insert_or_assign(keyEnd, m_valBegin);
            }
        }
                    
            //else if keybegin is at the end
                //if !(val == m_valBegin)
                    //assign (keybegin, val) and (keyEnd, m_valBegin)
        else if ((--m_map.end())->first < keyBegin)
        {
            if (!(val == m_valBegin))
            {
                //m_map[keyBegin] = val;
                //m_map[keyEnd] = m_valBegin;
                m_map.insert_or_assign(keyBegin, val);                
                m_map.insert_or_assign(keyEnd, m_valBegin);
            }
        }
                
            //else if keybegin is at the start 
                //if (val == m_valBegin)
                    //remove all entries up to keyEnd and assign (keyEnd, lastEntry removed val) if no entry removed dont assign anything
                //else
                    //assign (keyBegin, val) remove entries up to keyEnd remember the last removed entry val
                    //assign (keyEnd, lastEntry removed val if none then m_valBegin) Note: we dont have to look past because next cant be the same            
                
        else if (!(m_map.begin()->first < keyBegin))
        {
            if (val == m_valBegin)
            {
                V tempval = (m_map.lower_bound(keyEnd)--)->second;
                if (m_map.erase(m_map.lower_bound(keyBegin), m_map.lower_bound(keyEnd)) != 0)
                {
                    //m_map[keyEnd] = tempval;
                    m_map.insert_or_assign(keyEnd, tempval);
                }
            }
            
            else
            {
                //m_map[keyBegin] = val;
                m_map.insert_or_assign(keyBegin, val);
                V tempval = (m_map.lower_bound(keyEnd)--)->second;
                if (m_map.erase(m_map.lower_bound(keyBegin), m_map.lower_bound(keyEnd)) != 0)
                {
                    //m_map[keyEnd] = tempval;
                    m_map.insert_or_assign(keyEnd, tempval);
                }
                
                else
                {
                    //m_map[keyEnd] = m_valBegin;
                    m_map.insert_or_assign(keyEnd, m_valBegin);
                }
            }
        }
            //else if keybegin is in the middle need to check previous entry
                //if prev entry val not the same as val assign (beginKey, val)
                //remove entries until keyEnd store last entry removed val
                //if none removed and starting val same as curVal do nothing
                //else if none removed and starting val not the same as curVal assign (keyEnd, prevEntry before beinKey val) 
                //else assign (keyEnd, last removed entry val)
        else 
        {
            V beginTempVal = (m_map.lower_bound(keyBegin)--)->second;
            
            if (beginTempVal != val)
            {
                //m_map[keyBegin] = val;
                m_map.insert_or_assign(keyBegin, val);
            }
            
            V tempval = (m_map.lower_bound(keyEnd)--)->second;
            int eraseCount = m_map.erase(m_map.lower_bound(keyBegin), m_map.lower_bound(keyEnd));
            
            if (eraseCount == 0 && beginTempVal == val) {}            
            
            else if (eraseCount == 0 && beginTempVal != val)
            {
                //m_map[keyEnd] = beginTempVal;
                m_map.insert_or_assign(keyEnd, beginTempVal);
            }
            
            else
            {
                //m_map[keyEnd] = tempval;
                m_map.insert_or_assign(keyEnd, tempval);
            }
        }
    }
Editor is loading...
Leave a Comment