Skip to content

nol0n/segment_intersection

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

29 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

ΠšΡ€Π°Ρ‚ΠΊΠΎΠ΅ описаниС

Π’ΡƒΡ‚ Π² ΠΏΡ€ΠΎΠ³Ρ€Π°ΠΌΠΌΠ΅ Π°Π»Π³ΠΎΡ€ΠΈΡ‚ΠΌ ΠΏΡ€ΠΎΠ²Π΅Ρ€ΠΊΠΈ наличия пСрСсСчСния Π² мноТСствС ΠΎΡ‚Ρ€Π΅Π·ΠΊΠΎΠ², Ρ‚ΠΎΠ»ΡŒΠΊΠΎ самого Ρ„Π°ΠΊΡ‚Π° наличия пСрСсСчСния, Π±Π΅Π· Π²ΠΎΠ·Π²Ρ€Π°Ρ‚Π° ΠΊΠΎΠ½ΠΊΡ€Ρ‚Π½ΠΎΠΉ Ρ‚ΠΎΡ‡ΠΊΠΈ пСрСсСчСния, ΠΏΠ°Ρ€Ρ‹ ΠΎΡ‚Ρ€Π΅Π·ΠΊΠΎΠ² ΠΈ Ρ‚.Π΄.

Π Π΅Π°Π»ΠΈΠ·ΠΎΠ²Π°Π½ΠΎ Π΄Π²Π° ΠΌΠ΅Ρ‚ΠΎΠ΄Π°

  • Наивный - ΠΏΡ€ΠΎΠ²Π΅Ρ€ΠΊΠ° всСз со всСми, Ρ‡Ρ‚ΠΎ Π·Π°Π½ΠΈΠΌΠ°Π΅Ρ‚ O(n^2)
  • Алгоритм Π·Π°ΠΌΠ΅Ρ‚Π°ΡŽΡ‰Π΅ΠΉ прямой, Π³Π΄Π΅ Π² качСствС структуры Π΄Π°Π½Π½Ρ‹Ρ… для хранСния ΠΎΡ‚Ρ€Π΅Π·ΠΊΠΎΠ² ΠΈΡΠΏΠΎΠ»ΡŒΠ·ΡƒΠ΅Ρ‚ΡΡ B-Tree (2-3 Tree, Π½Π΅ B+ Tree), Π΅Π³ΠΎ ΡΠ»ΠΎΠΆΠ½ΠΎΡΡ‚ΡŒ - O(n*log(n))

Π‘Π°ΠΌΠΈ ΠΌΠ΅Ρ‚ΠΎΠ΄Ρ‹ находятся Π² service.cpp

B-Tree

Данная стуктура Π΄Π°Π½Π½Ρ‹Ρ… Ρ€Π΅Π°Π»ΠΈΠ·ΠΎΠ²Π°Π½Π° Π² Π²ΠΈΠ΄Π΅ шаблонного класса Π² Π·Π°Π³ΠΎΠ»ΠΎΠ²ΠΎΡ‡Π½Ρ‹Ρ… Ρ„Π°ΠΉΠ»Π°Ρ…, находится Π² ΠΏΠ°ΠΏΠΊΠ΅ headers.

Π‘Π±ΠΎΡ€ΠΊΠ° ΠΈ использованиС

  1. склоинруйтС Ρ€Π΅ΠΏΠΎΠ·ΠΈΡ‚ΠΎΡ€ΠΈΠΉ

    git clone https://github.com/nol0n/segment_intersection.git

  2. создайтС ΠΏΠ°ΠΏΠΊΡƒ build (я ΠΏΡ€Π΅Π΄ΠΏΠΎΡ‡ΠΈΡ‚Π°ΡŽ out-of-source build, ΠΊΠΎΠ³Π΄Π° ΠΏΠ°ΠΏΠΊΠ° с Π±ΠΈΠ½Π°Ρ€Π½ΠΈΠΊΠ°ΠΌΠΈ Π»Π΅ΠΆΠΈΡ‚ рядом с ΠΏΠ°ΠΏΠΊΠΎΠΉ рСпозитория)

    mkdir ..\build

  3. ΠΏΠ΅Ρ€Π΅ΠΉΠ΄ΠΈΡ‚Π΅ Π² ΠΏΠ°ΠΏΠΊΡƒ build

    cd .\build

  4. сконфигурирСйтС ΠΏΡ€ΠΎΠ΅ΠΊΡ‚ (ΠΏΡ€ΠΈ Ρ€Π°Π±ΠΎΡ‚Π΅ я использовал mingw)

    cmake ..\segment_intersection -G Ninja

  5. собСритС ΠΏΡ€ΠΎΠ΅ΠΊΡ‚

    cmake --build .

Π’ ΠΏΠ°ΠΏΠΊΠ΅ дирСктория_сборки\application Π±ΡƒΠ΄Π΅Ρ‚ seg_test, ΠΏΡ€ΠΈ Π΅Π³ΠΎ запускС Π±ΡƒΠ΄Π΅Ρ‚ Π²Ρ‹ΠΏΠΎΠ»Π½Π΅Π½ΠΎ Π΄Π²Π° Π½Π΅Π±ΠΎΠ»ΡŒΡˆΠΈΡ… тСста, Π³Π΄Π΅ сравнивааСтся быстродСйствиС Π°Π»Π³ΠΎΡ€ΠΈΡ‚ΠΌΠΎΠ². Π Π΅Π·ΡƒΠ»ΡŒΡ‚Π°Ρ‚Ρ‹ Π±ΡƒΠ΄ΡƒΡ‚ записаны Π² Ρ„Π°ΠΉΠ»Ρ‹ рядом с исполняСмым Ρ„Π°ΠΉΠ»ΠΎΠΌ.

About

A B-Tree implementation of sweep line algorithm for segment intersection

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published