Барлық жақын мәндер - All nearest smaller values

Жылы Информатика, барлық жақын мәндер мәселе келесі тапсырма болып табылады: сандар тізбегіндегі әр позиция үшін алдыңғы позициялардың арасынан кіші мән бар соңғы позицияны іздеңіз. Бұл мәселені параллель және параллель емес алгоритмдер арқылы тиімді шешуге болады: Беркман, Шибер және Вишкин (1993) Алдымен процедураны басқа параллель бағдарламалар үшін пайдалы подпрограмма ретінде анықтаған тиімді дамыды алгоритмдер оны шешу үшін Параллельді кездейсоқ қол жеткізу машинасы модель; оны шешуге болады сызықтық уақыт параллель емес компьютерде а стек негізделген алгоритм. Кейінірек зерттеушілер оны параллельді есептеудің басқа модельдерінде шешу алгоритмдерін зерттеді.

Мысал

Кіріс екілік деп есептейік ван дер Корпут тізбегі

0, 8, 4, 12, 2, 10, 6, 14, 1, 9, 5, 13, 3, 11, 7, 15.

(0) реттілігінің бірінші элементінде алдыңғы мән жоқ, 8-ден 4-ке дейінгі ең жақын (тек) кіші мән 0-ге тең. 12-ге дейінгі үш мәннің бәрі кіші, бірақ ең жақын мән 4-ке тең. Осылайша, осы реттіліктің алдыңғы ең кіші мәндері (алдыңғы кішігірім мәннің сызықшаға болмауын көрсетеді)

—, 0, 0, 4, 0, 2, 2, 6, 0, 1, 1, 5, 1, 3, 3, 7.

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

Қолданбалар

Беркман, Шибер және Вишкин (1993) ең жақын мәндерді есептеу арқылы параллельді түрде тиімді шешілуі мүмкін көптеген басқа мәселелерді атаңыз. Олардың қатарына мыналар кіреді:

  • Алгоритмдерді біріктіру, а-ны біріктіру қадамын есептеу біріктіру сұрыптау. Бұл алгоритмдердің кірісі екі сұрыпталған сандар жиымынан тұрады; қажетті шығыс - бұл бір сұрыпталған массивтегі сандардың жиынтығы. Егер біреуі сұрыпталған екі массивті біріктірсе, біріншісі өсу ретімен, ал екіншісі кему тәртібімен жүрсе, онда шығысындағы әрбір мәннің предшестері не оның ең жақын алдыңғы кіші мәні, не одан кейінгі ең кіші мәні болады (екеуінің қайсысы үлкен болса) , және сұрыпталған шығыс жиымындағы әрбір мәннің орнын осы екі жақын шамалардың позицияларынан оңай есептеуге болады.
  • Құрылысы Декарттық ағаштар. Декарттық ағаш - бұл а мәліметтер құрылымы енгізген Вуллемин (1980) және одан әрі зерттелген Габов, Бентли және Тарджан (1984) үшін ауқымды іздеу қосымшалар. Декарттық ағаштар анықтамасында да туындайды треп және рандомизацияланған екілік іздеу ағашы үшін деректер құрылымдары екілік іздеу. Мәндер тізбегінің декарттық ағашында әр мәнге арналған түйін бар. Ағаштың тамыры - бұл реттіліктің минималды мәні; әрбір басқа түйін үшін түйіннің ата-анасы не оның ең жақын кіші мәні, не одан кейінгі ең кіші мәні болып табылады (екеуінің қайсысы болса да үлкенірек). Осылайша, декарттық ағаштар сызықтық уақытта ең кіші мәндердің алгоритмі негізінде тұрғызылуы мүмкін.
  • Сәйкестік жақша. Егер әр жақшаның ұялау тереңдігімен бірге кіріс және ашық жақша таңбаларының тізбегі берілсе, онда әрбір ашық жақшаның сәйкестігі ұялау тереңдігі үлкен емес келесі жақын жақша болып табылады, сондықтан оны жақыннан табуға болады жақын жақшалардың пайдасына байланыстарды бұзатын есептеудің кіші мәндері. Егер ұя салу тереңдігі берілмесе, оларды a көмегімен есептеуге болады қосымшасы есептеу.

Осыған ұқсас әдістер проблемаларға қатысты қолданылуы мүмкін көпбұрышты триангуляция, дөңес корпус салу (дәйектілікті параллельдеу) Грэм сканері дөңес корпустың алгоритмі), ағаштардың екі өтпелі орамынан ағаштарды қалпына келтіру және квадрат салу.[1]

Тізбектелген алгоритм

Тізбектелген компьютерде а-ны пайдаланып барлық жақын кіші мәндерді есептеу қарапайым стек деректер құрылымы: осы уақытқа дейін өңделген және кез келген кейінгі мәндерден кіші мәндердің тізбегін сақтау үшін стек көмегімен мәндерді реттілік ретімен өңдейді. Жылы псевдокод, алгоритмі келесідей.

S = жаңа бос стектің деректер құрылымыүшін енгізу ретіндегі х істеу    уақыт S бос емес, ал S-нің жоғарғы элементі х-тен үлкен немесе оған тең істеу        поп С. егер S болып табылады бос содан кейін        х-тің алдыңғы кіші мәні жоқ басқа        x-ге жақын мән - S-тің жоғарғы элементі, x-ны S-ге итереді

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

Сызықтық уақыттың бірізді алгоритмі одан да қарапайым (Барбай, Фишер және Наварро (2012), Лемма 1) тіпті стек қажет емес; ол кіріс тізбегі A [1, n] жиымы түрінде берілген деп болжайды және алдыңғы индекстің кіші мәнінің j индексін A [i] P [i] -де сақтайды. Біз жасанды жалпы минимумды A [0] деңгейінде қабылдаймыз:

үшін мен 1-ден n-ге дейін: j = i-1 уақыт A [j]> = A [i]: j = P [j] P [i] = j

Параллель алгоритмдер

Беркман, Шибер және Вишкин (1993) бір уақытта оқылатын параллельді-жазбада барлық жақын кіші мәндерді қалай тиімді шешуге болатындығын көрсетті Параллельді кездейсоқ қол жеткізу машинасы. Тізбегі үшін n ретінде сақталатын мәндер массив, олар мәселенің O уақытында шешілуі мүмкін екенін көрсетеді (журнал журналыn) жалпы жұмыстың сызықтық мөлшерін қолдану. Барлық мәндер интервалдағы бүтін сандар болатын тізбектер үшінс], Беркман, Матиас және Рагде (1998) О-мен (журнал журналы журналы) байланысты жақсардыс); олар сондай-ақ жеткілікті үлкен мәндері үшін екенін көрсетті с, алдыңғы екі еселенген логарифмдік уақыт мәселеге қол жеткізуге болатын ең жақсы уақыт. Осы жұмыстан бастап параллель алгоритмдер параллельді есептеудің басқа модельдерінде параллель алгоритмдер, сонымен қатар параллельді есептеудің басқа модельдерінде жасалды. гиперкуб - құрылымдық байланыс желісі,[3] және синхронды параллель модель.[4]

Ескертулер

  1. ^ Берн, Эппштейн және Тенг (1999).
  2. ^ Кнут, Дональд (1968), «1-том: Іргелі алгоритмдер», Компьютерлік бағдарламалау өнері, Рединг, Массачусетс: Аддисон-Уэсли.
  3. ^ Kravets & Plaxton (1996).
  4. ^ He & Huang (2001).

Әдебиеттер тізімі