// file: examples/Interval_skip_list/intervals.C #include <CGAL/Interval_skip_list.h> #include <CGAL/Interval_skip_list_interval.h> #include <vector> #include <list> #include <iostream> typedef CGAL::Interval_skip_list_interval<double> Interval; typedef CGAL::Interval_skip_list<Interval> Interval_skip_list; int main() { Interval_skip_list isl; int i, n, d; n = 10; d = 3; //std::cin >> n >> d; std::vector<Interval> intervals(n); for(i = 0; i < n; i++) { intervals[i] = Interval(i, i+d); } std::random_shuffle(intervals.begin(), intervals.end()); isl.insert(intervals.begin(), intervals.end()); for(i = 0; i < n+d; i++) { std::list<Interval> L; isl.find_intervals(i, std::back_inserter(L)); for(std::list<Interval>::iterator it = L.begin(); it != L.end(); it++){ std::cout << *it; } std::cout << std::endl; } for(i = 0; i < n; i++) { isl.remove(intervals[i]); } return 0; }
// file: examples/Interval_skip_list/terrain.C #include <CGAL/Simple_cartesian.h> #include <CGAL/Delaunay_triangulation_2.h> #include <CGAL/Triangulation_euclidean_traits_xy_3.h> #include <CGAL/Interval_skip_list.h> #include <CGAL/Level_interval.h> #include <iostream> #include <fstream> typedef CGAL::Simple_cartesian<double> SC; typedef SC::Point_3 Point_3; typedef CGAL::Triangulation_euclidean_traits_xy_3<SC> K; typedef CGAL::Delaunay_triangulation_2<K> Delaunay; typedef Delaunay::Face_handle Face_handle; typedef Delaunay::Finite_faces_iterator Finite_faces_iterator; typedef CGAL::Level_interval<Face_handle> Interval; typedef CGAL::Interval_skip_list<Interval> Interval_skip_list; int main() { std::ifstream fin("terrain.pts"); // elevation ranges from 0 to 100 Delaunay dt; dt.insert(std::istream_iterator<Point_3>(fin), std::istream_iterator<Point_3>()); Interval_skip_list isl; for(Finite_faces_iterator fh = dt.finite_faces_begin(); fh != dt.finite_faces_end(); ++fh){ isl.insert(Interval(fh)); } std::list<Interval> level; isl.find_intervals(50, std::back_inserter(level)); for(std::list<Interval>::iterator it = level.begin(); it != level.end(); ++it){ std::cout << dt.triangle(it->face_handle()) << std::endl; } return 0; }