Оңтайлы екілік іздеу ағашы - Optimal binary search tree

Жылы Информатика, an оңтайлы екілік іздеу ағашы (Optimal BST), кейде а деп аталады салмаққа теңестірілген екілік ағаш,[1] Бұл екілік іздеу ағашы бұл мүмкін болатын іздеудің ең аз уақытын қамтамасыз етеді (немесе күтілетін іздеу уақыты ) қол жетімділіктің берілген бірізділігі үшін (немесе қол жеткізу ықтималдығы). Оңтайлы БСТ жалпы екі түрге бөлінеді: статикалық және динамикалық.

Ішінде статикалық оңтайлылық мәселе, ағаш салынғаннан кейін оны өзгерту мүмкін емес. Бұл жағдайда берілген кіру ықтималдығы үшін іздеудің ең аз уақытын қамтамасыз ететін ағаш түйіндерінің белгілі бір орналасуы бар. Элементтердің қол жетімділік ықтималдығы туралы мәліметтерді ескере отырып, статикалық оңтайлы ағашты құру немесе оған жуықтау үшін әр түрлі алгоритмдер бар.

Ішінде динамикалық оңтайлылық Ағашты кез-келген уақытта, әдетте, рұқсат беру арқылы өзгертуге болады ағаштардың айналуы. Ағаш тамырдан басталатын жүгіргі деп саналады, оны жылжытуға немесе модификациялауға қолдана алады. Бұл жағдайда курсорды мақсатты қатынау кезіндегі әрбір түйінге ретімен кіруге мәжбүр ететін осы операциялардың минималды шығындар тізбегі бар. The ағаш тұрақты болады деп болжанады бәсекелік коэффициент салыстырғанда динамикалық оңтайлы барлық жағдайда ағаш, дегенмен бұл әлі дәлелденбеген.

Статикалық оңтайлылық

Анықтама

Статикалық оптималдылық мәселесінде Кнут,[2] бізге жиынтығы берілген n реттелген элементтер және жиынтығы ықтималдықтар. Біз элементтерді белгілейтін боламыз арқылы және ықтималдықтар арқылы және арқылы . - элемент бойынша іздеудің ықтималдығы . Үшін , арасындағы элементті іздеудің ықтималдығы және , - элементтерден іздеудің ықтималдығы - бұл аз , және - бұл элементті іздеудің ықтималдығы - бұл одан үлкен . Мыналар ықтималдықтар барлық мүмкін іздеуді қамтиды, сондықтан біреуі қосылады.

Статикалық оңтайлылық мәселесі мынада оңтайландыру мәселесі ескере отырып, күтілетін іздеу уақытын азайтатын екілік іздеу ағашын табу ықтималдықтар. Жиынтығында мүмкін ағаштардың саны ретінде n элементтері болып табылады ,[2] бұл экспоненциалды n, күшпен іздеу әдетте мүмкін шешім емес.

Кнуттың динамикалық бағдарламалау алгоритмі

1971 жылы Кнут салыстырмалы түрде қарапайым жариялады динамикалық бағдарламалау тек статикалық оңтайлы ағашты құруға қабілетті алгоритм O(n2) уақыт.[2] Кнуттың негізгі түсінігі статикалық оңтайлылық мәселесі көрінеді оңтайлы құрылым; яғни, егер белгілі бір ағаш берілген ықтималдықты үлестіру үшін статикалық тұрғыдан оңтайлы болса, онда оның сол және оң жақ қосалқы ағаштары олардың үлестірілуінің сәйкес жиындары үшін де статикалық оңтайлы болуы керек.

Мұны көру үшін Кнут ағаштың «өлшенген жол ұзындығы» деп атайтынын қарастырайық. Ағаштың n элемент бойынша өлшенген жол ұзындығы барлық ұзындықтардың қосындысына тең ықтималдықтарымен өлшенген мүмкін іздеу жолдары. Жолдың минималды өлшенген ұзындығы бар ағаш, анықтама бойынша, статикалық тұрғыдан оңтайлы болып табылады.

Бірақ өлшенген жол ұзындығы қызықты қасиетке ие. E екілік ағаштың өлшенген жол ұзындығы болсын, EL оның сол жақ ағашының өлшенген жол ұзындығы және ER оның оң жақ ағашының өлшенген жол ұзындығы болуы керек. Сонымен қатар W ағаштағы барлық ықтималдықтардың қосындысы болсын. Екі тармақ түбірге бекітілгенде, оның әр элементінің тереңдігі (және, осылайша, оның іздеу жолдарының әрқайсысы) бір-біріне көбейетініне назар аударыңыз. Сондай-ақ, тамырдың өзі бір тереңдікке ие екенін ескеріңіз. Бұл дегеніміз, ағаш пен оның екі кіші ағашы арасындағы өлшенген жол ұзындығының айырмашылығы дәл осы қайталануға әкелетін ағаштағы әрбір ықтималдықтың жиынтығын құрайды:

Бұл қайталану табиғи динамикалық бағдарламалау шешіміне әкеледі. Келіңіздер арасындағы барлық мәндер үшін статикалық оңтайлы іздеу ағашының өлшенген жол ұзындығы болуы керек амен және аj, рұқсат етіңіз сол ағаштың жалпы салмағы болып, рұқсат етіңіз оның түбірінің индексі болу. Алгоритмді келесі формулалар көмегімен құруға болады:

Бұл алгоритмді аңғалдықпен жүзеге асыру қажет O(n3) уақыт, бірақ Кнуттың мақаласында кейбір ескертулер бар, оларды тек өзгертілген алгоритмді құру үшін пайдалануға болады O(n2) уақыт.

Мехлхорнның жуықтау алгоритмі

Әзірге O(n2) Кнуттың алгоритмі қабылдаған уақыт өрескел күш іздеуге қажет болатын экспоненциалды уақыттан едәуір жақсы, ағаштағы элементтер саны өте көп болған кезде практикалық болу өте баяу.

1975 жылы, Курт Мехлхорн әлдеқайда қарапайым алгоритмді тек статикалық оңтайлы ағашқа жуықтау үшін қолдануға болатындығын дәлелдейтін құжат жариялады уақыт.[3] Бұл алгоритмде сол және оң жақ ағаштардың жалпы салмағын (ықтималдығы бойынша) теңдестіру үшін ағаштың тамыры таңдалады. Содан кейін бұл стратегия әр кіші ағашта рекурсивті түрде қолданылады.

Бұл стратегияның жақсы жақындатуды интуитивті түрде кез-келген жол бойындағы кіші ағаштардың салмақтары геометриялық кемитін дәйектілікке өте жақын нәрсе құрайтынын ескере отырып байқауға болады. Шын мәнінде, бұл стратегия ағаштың пайда болуына әкеледі, оның өлшенген жол ұзындығы ең көп болады

мұндағы H энтропия ықтималдықтың таралуы. Ешқандай оңтайлы іздеу ағашы ешқашан өлшенген жол ұзындығынан жақсы бола алмайтындықтан

бұл жуықтау өте жақын.[3]

Ху-Такер және Гарсия-Вахс алгоритмдері

Бұл ерекше жағдайда мәндері нөлге тең, оңтайлы ағашты уақытында табуға болады . Мұны алдымен Т. Ху дәлелдеді және Алан Такер олар 1971 жылы шығарған мақаласында. Гарсия мен Вахстың кейінірек жеңілдетуі Garsia – Wachs алгоритмі, бірдей салыстыруларды бірдей тәртіпте орындайды. Алгоритм а-ны қолдану арқылы жұмыс істейді ашкөздік алгоритмі әр жапырақ үшін оңтайлы биіктігі бар, бірақ жұмыс істемейтін ағаш салу, содан кейін биіктігі бірдей басқа екілік іздеу ағашын салу.[4]

Динамикалық оңтайлылық

Сұрақ, Web Fundamentals.svgИнформатикадағы шешілмеген мәселе:
Тарату ағаштары кез-келген екілік іздеу ағашының алгоритмі сияқты жақсы нәтиже бере ме?
(информатикадағы шешілмеген мәселелер)

Анықтама

Динамикалық оңтайлылықтың бірнеше әр түрлі анықтамалары бар, олардың барлығы жұмыс уақыты бойынша тұрақты факторға тең.[5] Мәселе алғаш рет жанама түрде енгізілген Слеатор және Таржан олардың қағазында ағаштар,[6] бірақ Демейн т.б. бұл туралы өте жақсы ресми мәлімдеме беріңіз.[5]

Динамикалық оңтайлылық мәселесінде бізге x қатынасу тізбегі берілген1, ..., xм 1, ..., n пернелерінде. Әр қол жетімділік үшін бізге а көрсеткіш біздің BST-нің тамырына және келесі операциялардың кез-келгенін орындау үшін меңзерді қолдана алады:

  1. Меңзерді ағымдағы түйіннің сол жақ бөлігіне жылжытыңыз.
  2. Меңзерді ағымдағы түйіннің оң жақ бөлігіне жылжытыңыз.
  3. Меңзерді ағымдағы түйіннің ата-анасына жылжытыңыз.
  4. Бір орындаңыз айналу ағымдағы түйінде және оның ата-анасында.

(Бұл қол жетімділік кезінде ағашты қайта реттейтін төртінші операцияның болуы, бұл оны жасайды динамикалық оптикалық проблема.)

Әрбір қол жетімділік үшін біздің BST алгоритмі меңзер соңында мақсатты мәні бар түйінге аяқталғанша, жоғарыда аталған кез-келген әрекеттерді орындай алады.мен. Берілген динамикалық BST алгоритміне қатынау тізбегін орындау үшін уақыт қажет, сол кезектілік кезінде орындалған операциялардың жалпы санына тең. Кез-келген элементтер жиынтығына кез-келген қол жетімділіктің кезектілігін ескере отырып, осы қол жетімділікті орындау үшін операциялардың жалпы саны ең аз болады. Біз осы минимумға жақындағымыз келеді.

Мұны жүзеге асыру мүмкін емес «Құдайдың алгоритмі «қатынау тізбегі қандай болатынын алдын-ала білмей, OPT (X) -ті X қатынау тізбегі үшін орындайтын операциялардың саны ретінде анықтай аламыз және алгоритм динамикалық оңтайлы егер кез келген Х үшін ол уақытында Х-ны орындайды O (OPT (X)) (яғни оның тұрақтысы бар бәсекелік коэффициент ).[5]

Мұндай қасиетке ие болуы мүмкін бірнеше деректер құрылымы бар, бірақ дәлелденбеген. Бұл ашық мәселе осы модельде мәліметтердің динамикалық оңтайлы құрылымы бар ма.

Ағаштар

The ағаш формасы болып табылады екілік іздеу ағашы 1985 жылы Даниэль Слеатор мен Роберт Тарджан ойлап тапты, олар бойынша стандартты іздеу жұмыстары жүреді амортизацияланған уақыт.[7] Болжам бойынша динамикалық оңтайлы қажетті мағынада. Яғни, таралу ағашы O (OPT (X)) уақытында кез-келген жеткілікті ұзындықтағы X кезектілігін орындайды деп саналады.[6]

Танго ағаштары

The танго ағашы - 2004 жылы ұсынылған деректер құрылымы Эрик Демейн және уақытында кез-келген X ұзындыққа жету ретін дәлелдеген басқалары . Бұл динамикалық оңтайлы болмаса да, бәсекелестік коэффициенті n-дің ақылға қонымды мәндері үшін әлі де өте аз.[5]

Басқа нәтижелер

2013 жылы, Джон Яконо пайдаланатын мақала жариялады екілік іздеу ағаштарының геометриясы кез келген екілік іздеу ағашының алгоритмі динамикалық оңтайлы болса, динамикалық оңтайлы алгоритмді ұсыну.[8] Түйіндер екі өлшемдегі нүктелер ретінде түсіндіріледі, ал оңтайлы қол жеткізу реті ең кіші болып табылады арборлық қанағаттандырылды сол тармақтардың орнын ауыстыру. Жайық ағаштары мен танго ағаштарынан айырмашылығы, Iacono деректерінің құрылымы қол жетімділіктің кезек-кезегінің тұрақты уақытында іске асырылатындығы белгілі емес, сондықтан динамикалық тұрғыдан оңтайлы болса да, ол тұрақты емес фактордың көмегімен іздеу ағашының басқа құрылым құрылымдарына қарағанда баяу болуы мүмкін.

The төменгі шекара болып табылады асимптотикалық төменгі шекара динамикалық оңтайлылық туралы.

Сондай-ақ қараңыз

Ескертулер

  1. ^ Tremblay, Жан-Пол; Честон, Грант А. (2001). Деректер құрылымы және бағдарламалық жасақтама объектіге бағытталған доменде. Eiffel Edition / Prentice Hall. ISBN  978-0-13-787946-5.
  2. ^ а б c Кнут, Дональд Э. (1971), «Оңтайлы екілік іздеу ағаштары», Acta Informatica, 1 (1): 14–25, дои:10.1007 / BF00264289, S2CID  62777263
  3. ^ а б Мехлхорн, Курт (1975), «Жақын екілік іздеу ағаштары», Acta Informatica, 5 (4): 287–295, дои:10.1007 / BF00264563, S2CID  17188103
  4. ^ Кнут, Дональд Э. (1998), «Algorithm G (Garsia - Wachs алгоритмі оңтайлы екілік ағаштар үшін»), Компьютерлік бағдарламалау өнері, т. 3: сұрыптау және іздеу (2-ші басылым), Аддисон-Уэсли, 451-453 бб. Тарих және библиография, 453–454 б. Қараңыз.
  5. ^ а б c г. Демейн, Эрик Д .; Гармон, Дион; Яконо, Джон; Патраску, Михай (2004), Динамикалық оңтайлылық - дерлік (PDF), 484-490 б., CiteSeerX  10.1.1.99.4964, дои:10.1109 / FOCS.2004.23, ISBN  978-0-7695-2228-9
  6. ^ а б Слеатор, Даниэль; Тарджан, Роберт (1985), «Өзін-өзі реттейтін екілік іздеу ағаштары», ACM журналы, 32 (3): 652–686, дои:10.1145/3828.3835, S2CID  1165848
  7. ^ Кормен, Томас Х .; Лейзерсон, Чарльз Е .; Ривест, Рональд; Stein, Clifford (2009). Алгоритмдермен таныстыру (PDF) (Үшінші басылым). MIT Press. б. 503. ISBN  978-0-262-03384-8. Алынған 31 қазан 2017.
  8. ^ Яконо, Джон (2013), «Динамикалық оңтайлылық болжамына ұмтылу», arXiv:1306.0207 [cs.DS ]