Compare commits
3 commits
2004cd06cf
...
2317285d0f
Author | SHA1 | Date | |
---|---|---|---|
Bruno BELANYI | 2317285d0f | ||
Bruno BELANYI | 8ea4fd373b | ||
Bruno BELANYI | 2a6b89e420 |
|
@ -15,26 +15,45 @@ public:
|
||||||
if (!(begin < end))
|
if (!(begin < end))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto const end_val = (*this)[end];
|
auto it = underlying_.upper_bound(end);
|
||||||
underlying_.erase(underlying_.lower_bound(begin),
|
auto const end_val = at_upper_bound(it);
|
||||||
underlying_.upper_bound(end));
|
|
||||||
if (!((*this)[begin] == val))
|
bool insert_begin = !(val == init_);
|
||||||
underlying_.insert({begin, val});
|
|
||||||
if (!((*this)[end] == end_val))
|
while (it != underlying_.begin()) {
|
||||||
underlying_.insert({end, end_val});
|
it = std::prev(it);
|
||||||
|
auto begin_found = it->first < begin;
|
||||||
|
if (begin_found) {
|
||||||
|
insert_begin = !(val == it->second);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (it != underlying_.end())
|
||||||
|
// Account for up-coming `std::prev` with `++`
|
||||||
|
underlying_.erase(it++);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (insert_begin)
|
||||||
|
it = underlying_.insert(it, {begin, val});
|
||||||
|
// Get the proper upper-bound for `end`
|
||||||
|
it = (it == underlying_.end() || end < it->first) ? it : std::next(it);
|
||||||
|
if (!(at_upper_bound(it) == end_val))
|
||||||
|
underlying_.insert(it, {end, end_val});
|
||||||
}
|
}
|
||||||
|
|
||||||
V const& operator[](K const& key) const {
|
V const& operator[](K const& key) const {
|
||||||
auto it = underlying_.upper_bound(key);
|
return at_upper_bound(underlying_.upper_bound(key));
|
||||||
if (it == underlying_.begin())
|
|
||||||
return init_;
|
|
||||||
return std::prev(it)->second;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Used in testing
|
// Used in testing
|
||||||
friend class ::IntervalMapTest;
|
friend class ::IntervalMapTest;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
V const& at_upper_bound(std::map<K, V>::const_iterator it) const {
|
||||||
|
if (it == underlying_.begin())
|
||||||
|
return init_;
|
||||||
|
return std::prev(it)->second;
|
||||||
|
}
|
||||||
|
|
||||||
V init_;
|
V init_;
|
||||||
std::map<K, V> underlying_{};
|
std::map<K, V> underlying_{};
|
||||||
};
|
};
|
||||||
|
|
|
@ -1 +1,3 @@
|
||||||
interval_map_dep = declare_dependency(include_directories: 'include')
|
interval_map_dep = declare_dependency(include_directories: 'include')
|
||||||
|
|
||||||
|
install_headers('include/interval-map/interval-map.hh', subdir: 'interval-map')
|
||||||
|
|
|
@ -242,6 +242,12 @@ TEST_F(IntervalMapTest, fuzzing_003) {
|
||||||
assign(-110, -10, 4);
|
assign(-110, -10, 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_F(IntervalMapTest, fuzzing_004) {
|
||||||
|
assign(-20, 120, 1);
|
||||||
|
assign(50, 110, 0);
|
||||||
|
assign(-120, 100, 0);
|
||||||
|
}
|
||||||
|
|
||||||
TEST_F(IntervalMapTest, randomized_test) {
|
TEST_F(IntervalMapTest, randomized_test) {
|
||||||
auto const seed = []() {
|
auto const seed = []() {
|
||||||
std::random_device r;
|
std::random_device r;
|
||||||
|
|
Loading…
Reference in a new issue