Arbre de segments

En informatique, un arbre segment (en anglais segment tree), est un arbre enraciné pour stocker des intervalles ou des segments. Il permet des requêtes afin de savoir quels segments contiennent un certain point. C'est, en principe, une structure statique : c'est une structure qui ne peut plus être modifiée une fois qu'elle est créée. Une structure de données similaire est l'arbre intervalle.

Un arbre segment pour un ensemble I de n intervalles utilise un stockage de O(n log n) et peut être construit en un temps de O(n log n). Dans un arbre segment on peut rechercher tous les intervalles qui contiennent un certain point (la requête) en O(log n + k), où k est le nombre d'intervalles ou segments extraits[1].

Les applications de l'arbre segment sont dans les domaines de la géométrie algorithmique et du système d'information géographique.

L'arbre segment peut aussi être généralisé à des espaces avec des plus grandes dimensions.

Description de la structure

Cette section décrit la structure d'un arbre segment à 1 dimension.

Soit S l'ensemble d'intervalles, ou segments. Soit p1, p2, ..., pm la liste des points d'extrémités d'intervalle distincts, trié de gauche à droite. On considère le partitionnement de la droite des réels induit par ces points. Les régions de ce partitionnement sont nommés intervalles élémentaires. Ainsi, les intervalles élémentaires, sont de gauche à droite.

Comme cela, la liste des intervalles élémentaires consistent à des intervalles ouverts entre deux points d'extrémités consécutifs pi et pi+1, alternés avec des intervalles fermés qui consistent en un seul point d'extrémité. Les points isolés sont traités comme des intervalles car la réponse à une requête n'est pas nécessairement la même à l'intérieur d'un intervalle élémentaire et ses points d'extrémités[2].

Exemple graphique de la structure d'un arbre segment. Cette instance est construite pour les segments montrés en bas.

Étant donné un ensemble I d'intervalles, ou segments, un arbre segment T pour I est structuré comme ceci :

  • T est un arbre binaire
  • Ses feuilles correspondant aux intervalles élémentaires induits par les points d'extrémités dans I, d'une manière ordonnée : la feuille la plus à gauche correspond à l'intervalle le plus à gauche, ainsi de suite. L'intervalle élémentaire correspondant à la feuille v est noté Int(v).
  • Les nœuds internes de T correspondent à des intervalles qui sont l'union d'intervalles élémentaires : l'intervalle Int(N) correspondant au nœud N est l'union des intervalles correspondants aux feuilles de l'arbre qui débute à la racine N. Cela implique que Int(N) est l'union des intervalles de ces deux fils (sous-arbres).
  • Chaque nœud ou feuille v de T stocke l'intervalle Int(v) ou dans certaines structures de données un ensemble d'intervalles. Ce sous-ensemble canonique de nœuds v contient les intervalles [x, x′] de I de telle manière que [x, x′] contient Int(v) et ne contient pas Int(parent(v)). Cela étant, chaque nœud dans T stocke les segments qui couvrent son intervalle, mais qui ne couvrent pas l'intervalle de son parent[3].

Exigences de stockage

Cette section analyse le coût du stockage d'un arbre segment à 1 dimension.

Un arbre segment T sur un ensemble I de n intervalles utilise un stockage de O(n log n).

Preuve:
Lemme: Tout intervalle [x, x′] de I est stocké dans l'ensemble canonique pour, au maximum, deux nœuds à la même profondeur.
Preuve: Soit v1, v2, v3 trois nœuds à la même profondeur, numérotés de gauche à droite ; et soit p(v) le nœud père de n'importe quel nœud v. Supposons que [x, x′] est stocké à v1 and v3. Cela signifie que [x, x′] couvre en entier l'intervalle depuis le point d'extrémité gauche de Int(v1) jusqu'au point d'extrémité droite de Int(v3). Remarquons que tous les segments à un niveau particulier ne se chevauchent pas et ordonnés de gauche à droite : par construction, cela est vrai pour le niveau contenant les feuilles, et la propriété n'est pas perdue en allant au niveau au-dessus en combinant par pair les segments adjacents. Maintenant, soit parent(v2) = parent(v1), ou c'est celui à droite de ce dernier (les arêtes dans ce graphe ne se croisent pas). Dans le premier cas, le point le plus à gauche de Int(parent(v2)) est le même que le point le plus à gauche de Int(v1) ; dans le second cas, le point le plus à gauchede Int(parent(v2)) est à droite du point le plus à droite de Int(parent(v1)), et ainsi, aussi à droite du point le plus à droite de Int(v1). Dans les deux cas, Int(parent(v2)) débute au niveau, ou à droite, du point le plus à gauche de Int(v1). Un raisonnement similaire montre que Int(parent(v2)) se termine au niveau, ou à gauche, du point le plus à droite de Int(v3). Int(parent(v2)) doit ainsi être contenu dans [x, x′] ; par conséquent [x, x′] ne sera pas stocké à v2.
L'ensemble I a au plus 4n + 1 intervalles élémentaires. Car T est un arbre binaire équilibré avec au plus 4n + 1 feuilles, sa hauteur est O(logn). Étant donné qu'un intervalle est au plus stocké deux fois à une certaine profondeur de l'arbre, ainsi le stockage total est O(nlogn)[4].

Construction

Cette section décrit la construction d'un arbre segment à 1 dimension.

Un arbre segment à partir de l'ensemble de segments I, peut-être construit comme ceci. Premièrement, les points d'extrémités des intervalles dans I sont triés. les intervalles élémentaires sont obtenus à partir de cela. Ensuite, un arbre binaire équilibré est construit sur les intervalles élémentaires, et pour chaque sommet v l'intervalle Int(v) est déterminé. Il reste à calculer le sous-ensemble canonique pour les nœuds. Pour réussir cela, les intervalles dans I sont insérés un par un dans l'arbre segment. Un intervalle X = [x, x′] peut être inséré dans un sous-arbre enraciné à t, en utilisant la procédure suivante[5] :

  • Si Int(T) est contenu dans X alors stocker X à T, et finir.
  • Else :
  • Si X intersecte l'intervalle du fils gauche de T, alors insérer X dans ce fils, récursivement.
  • Si X intersecte l'intervalle du fils droit de T, alors insérer X dans ce fils, récursivement.

L'opération de construction complète nécessite le temps O(nlogn), n étant le nombre de segments dans I.

Preuve
Trier les points d'extrémités prend O(nlogn). Construire un arbre binaire équilibré depuis les points d'extrémités nécessite un temps linéaire en n.
L'insertion d'un intervalle X = [x, x′] dans l'arbre coûte O(logn).
Preuve:Visiter chaque nœud prend un temps constant (en assumant que les sous-ensembles canoniques sont stockés dans une structure de données simple, comme une liste chaînée). Quand on visite un nœud v, soit on stocke X à v, ou Int(v) contient un point d'extrémité de X. Comme prouvé au-dessus, un intervalle est au plus stocké deux fois à chaque niveau de l'arbre. Il y a aussi au plus un nœud à chaque niveau où son intervalle correspondant contient x, et un nœud où son intervalle contient x′. Donc, au plus quatre nœuds par niveau sont visités. Étant donné qu'il y a O(logn) niveaux, le coût total de l'insertion est O(logn)[1].

Requête

Cette section décrit l'opération d'une requête dans un arbre segment à 1 dimension.

Une requête pour un arbre segment, reçoit une point qx (qui devrait être une des feuilles de l'arbre), et retrouve une liste de tous les segments stockés qui contiennent le point qx.

Formellement énoncé ; en fonction d'un nœud (sous-arbre) v et une requête sur un point qx, la requête peut être faite en utilisant l'algorithme suivant :

  • Signaler tous les intervalles dans I(v)
  • Si v n'est pas une feuille :
    • Si qx est dans Int(fils gauche de v) alors
      • Réaliser une requête dans le fils gauche de v.
    • Si qx est dans Int(fils droit de v) alors
      • Réaliser une requête dans le fils droit de v.

Si un arbre segment contient n intervalles, ceux qui contiennent un point d'une requête peuvent être signalés en un temps O(logn + k), où k est le nombre d'intervalles signalés.

Proof:L'algorithme de requête visite un nœud par niveau de l'arbre, donc O(logn) nœuds au total. D'un autre côté, à un nœud v, les segments dans I sont signalés en un temps O(1 + kv), où kvest le nombre d'intervalles signalés au nœud v. La somme de tous les kv pour tous les nœuds v visités, est k, le nombre de segments signalés[4].

Généralisation pour de plus grandes dimensions

L'arbre segment peut être généralisé pour des espaces à plus grandes dimensions, dans la forme d'un arbre segment à plusieurs niveaux. Les versions à plus de dimensions, l'arbre segment stocke une collection d'axes-parallèles (hyper-)rectangles, et peut retrouver les rectangles qui contiennent le point d'une certaine requête. La structure utilise un espace de O(nlogdn) et résout les requêtes en O(logdn).

L'utilisation de cascade fractionnée diminue la borne du temps de requête par un facteur logarithmique. L'utilisation d'arbre intervalle au niveau le plus profond des structures associées diminue la borne inférieure du stockage par un facteur logarithmique[6].

Notes

Une requête qui demande tous les intervalles qui contiennent un certain point est souvent mentionné en anglais comme stabbing query[7].

L'arbre segment est moins efficace que l'arbre intervalle pour les requêtes de distance dans 1 dimension, cela est dû au stockage qui est davantage conséquent : O(nlogn) contre O(n) pour l'arbre d'intervalle. L'importance de l'arbre segment est que les segments dans chaque nœud, son sous-ensemble canonique peut être stocké d'une manière arbitraire[7].

Pour n intervalles où les points d'extrémités sont dans une petite plage de nombres entiers (par exemple, dans la plage [1,...,O(n)]), une structure de donnée optimale[Laquelle ?] existe avec un temps de prétraitement linéaire et un temps de requête de O(1+k) pour signaler tous les k intervalles qui contiennent le point d'une certaine requête.

Un autre avantage de l'arbre segment est qu'il peut être facilement adapté aux requêtes de comptage ; qui est de signaler le nombre de segments qui contiennent un certain point, au lieu de signaler les segments eux-mêmes. À la place de stocker les intervalles dans des sous-ensembles canoniques, on peut simplement stocker le nombre qu'ils sont. Ainsi un arbre linéaire utilise un stockage linéaire, et requiert un temps de requête de O(log n)[8].

Des versions avec de plus grandes dimensions pour l'arbre intervalle et pour les arbres de recherche prioritaires n'existent pas ; cela étant, il n'y a pas d'extension claire de ces structures qui résout le problème analogue dans des dimensions supérieurs. Mais les structures peuvent être utilisés comme structures associées des arbres segments[6].

Histoire

L'arbre segment a été inventé par Jon Louis Bentley en 1977, dans "Solutions to Klee’s rectangle problems"[7].

Références

  1. a et b de Berg et al. 2000, p. 227
  2. de Berg et al. 2000, p. 224
  3. de Berg et al. 2000, p. 225–226
  4. a et b de Berg et al. 2000, p. 226
  5. de Berg et al. 2000, p. 226–227
  6. a et b de Berg et al. 2000, p. 230
  7. a b et c de Berg et al. 2000, p. 229
  8. de Berg et al. 2000, p. 229–230

Sources citées

Read other articles:

artikel ini perlu dirapikan agar memenuhi standar Wikipedia. Tidak ada alasan yang diberikan. Silakan kembangkan artikel ini semampu Anda. Merapikan artikel dapat dilakukan dengan wikifikasi atau membagi artikel ke paragraf-paragraf. Jika sudah dirapikan, silakan hapus templat ini. (Pelajari cara dan kapan saatnya untuk menghapus pesan templat ini) Artikel ini tidak memiliki referensi atau sumber tepercaya sehingga isinya tidak bisa dipastikan. Tolong bantu perbaiki artikel ini dengan menamba...

 

Chronologie de la France ◄◄ 1788 1789 1790 1791 1792 1793 1794 1795 1796 ►► Chronologies La Garde nationale de Paris part pour l’armée, septembre 1792, toile de Léon Cogniet.Données clés 1789 1790 1791  1792  1793 1794 1795Décennies :1760 1770 1780  1790  1800 1810 1820Siècles :XVIe XVIIe  XVIIIe  XIXe XXeMillénaires :-Ier Ier  IIe  IIIe Chronologies géographiques Afrique Afrique du Sud, Algérie, Angola, Bénin, Botswa...

 

Keuskupan AmboinaDioecesis AmboinaensisKatolik Gereja Katedral AmboinaLokasiNegaraIndonesiaWilayahMalukuMaluku UtaraProvinsi gerejawiMakassarWilayah pastoralKota AmbonSeram–BuruKepulauan AruKei KecilKei BesarKepulauan Tanimbar–Maluku Barat DayaMaluku UtaraKantor pusatJl. Pattimura No. 26, Kel. Uritetu, Kec. Sirimau, Kota Ambon 97124Koordinat3°41′51″S 128°11′08″E / 3.697471°S 128.185669°E / -3.697471; 128.185669StatistikLuas77.990 km2 (30.110&#...

WTA Tour Championships 2011 Sport Tennis Data 25 - 30 ottobre Edizione 41ª (singolare) / 36ª (doppio) Superficie Terra rossa Località Istanbul Campioni Singolare Petra Kvitová Doppio Liezel Huber / Lisa Raymond 2010 2012 Il WTA Tour Championships 2011 (conosciuto anche come Sony Ericsson Championships) si è giocato ad Istanbul, in Turchia dal 25 al 30 ottobre. Il torneo si è tenuto al Sinan Erdem Spor Salonu. Il Masters femminile, dotato di un montepremi di 4.550.000 dollari, vede in c...

 

У этого термина существуют и другие значения, см. Чайки (значения). Чайки Доминиканская чайкаЗападная чайкаКалифорнийская чайкаМорская чайка Научная классификация Домен:ЭукариотыЦарство:ЖивотныеПодцарство:ЭуметазоиБез ранга:Двусторонне-симметричныеБез ранга:Вторич...

 

This article is about the town in Oxfordshire. For other uses, see Burford (disambiguation). Town in Oxfordshire, England Human settlement in EnglandBurfordLooking north along 'The Hill'BurfordLocation within OxfordshirePopulation1,422 (parish, 2011 Census)OS grid referenceSP2512Civil parishBurfordDistrictWest OxfordshireShire countyOxfordshireRegionSouth EastCountryEnglandSovereign stateUnited KingdomPost townBurfordPostcode districtOX18Dialling code01993Po...

Sceaux 行政国 フランス地域圏 (Région) イル=ド=フランス地域圏県 (département) オー=ド=セーヌ県郡 (arrondissement) アントニー郡小郡 (canton) 小郡庁所在地INSEEコード 92071郵便番号 92330市長(任期) フィリップ・ローラン(2008年-2014年)自治体間連合 (fr) メトロポール・デュ・グラン・パリ人口動態人口 19,679人(2007年)人口密度 5466人/km2住民の呼称 Scéens地理座標 北緯48度4...

 

This biography of a living person needs additional citations for verification. Please help by adding reliable sources. Contentious material about living persons that is unsourced or poorly sourced must be removed immediately from the article and its talk page, especially if potentially libelous.Find sources: Kamaljit Bawa – news · newspapers · books · scholar · JSTOR (July 2018) (Learn how and when to remove this message) Kamal BawaKamaljit Singh Bawa ...

 

2016年美國總統選舉 ← 2012 2016年11月8日 2020 → 538個選舉人團席位獲勝需270票民意調查投票率55.7%[1][2] ▲ 0.8 %   获提名人 唐納·川普 希拉莉·克林頓 政党 共和黨 民主党 家鄉州 紐約州 紐約州 竞选搭档 迈克·彭斯 蒂姆·凱恩 选举人票 304[3][4][註 1] 227[5] 胜出州/省 30 + 緬-2 20 + DC 民選得票 62,984,828[6] 65,853,514[6]...

الحزب الجمهوري الديمقراطي   البلد الولايات المتحدة  تاريخ التأسيس 1791  تاريخ الحل 1825    الحزب الديمقراطي  قائد الحزب توماس جفرسونجيمس ماديسون  المقر الرئيسي واشنطن العاصمة  الأيديولوجيا الجمهوريانية في الولايات المتحدة،  وفلسفة الإصلاح الزراعي،  ...

 

中国自然保护区分为国家级自然保护区和地方各级自然保护区,指的是中華人民共和國境內的自然保护区,国家级自然保护区由国务院批准建立。 中国现有474处国家级自然保护区。各级自然保护地总数超过12,000个[1]。 批建时间 以下是国务院批复(或因有相关批示而可被视为)同意建立国家级自然保护区的日期: 1956年6月30日:鼎湖山计一处; 1975年3月20日:卧龙、蜂�...

 

City in California, United States City in California, United StatesPomona, CaliforniaCity Clockwise from top: Antiques Row, Abraham Lincoln Elementary School, California State Polytechnic University, Pomona, Lincoln Park Historic District FlagSealNickname: P-Town[citation needed]Motto: Vibrant – Safe – Beautiful[1]Location of Pomona in Los Angeles County and the U.S. state of CaliforniaPomonaLocation of Pomona, California in the United StatesShow map of...

Campeonato de Japón de Ciclismo en Ruta Ciclismo en ruta Maillot de CampeónDatos generalesPaís Japón JapónCategoría CNOrganizador Japan Cycling FederationFormato Carrera de un día Palmarés masculinoGanador actual Masaki YamamotoPalmarés femeninoGanadora actual Eri Yonamine[editar datos en Wikidata] Los Campeonatos de Japón de Ciclismo en Ruta se organizan anualmente desde el año 1997 para determinar el campeón ciclista de Japón de cada año. El título se otorga al...

 

Long Island Rail Road station in Suffolk County, New York Great RiverGreat River station in May 2015.General informationLocationConnetquot Avenue & Hawthorne AvenueEast Islip, New YorkCoordinates40°44′26″N 73°10′12″W / 40.740476°N 73.17°W / 40.740476; -73.17Owned byLong Island Rail RoadPlatforms2 side platformsTracks2ConstructionParkingYes (free)AccessibleYesOther informationFare zone10HistoryOpened1897Rebuilt1943, 2001Passengers2012—2014310&...

 

2012 live album by The GroupLiveLive album by The GroupReleased2012RecordedSeptember 13, 1986VenueJazz Center of New York, New York CityGenreFree jazzLabelNoBusiness RecordsNBCD50ProducerDanas Mikailionis Live is a live album by the cooperative jazz ensemble known as The Group, featuring saxophonist Marion Brown, trumpeter Ahmed Abdullah, violinist Billy Bang, bassists Sirone and Fred Hopkins, and drummer Andrew Cyrille. The band's sole release, it was recorded on September 13, 1986, ...

Ataque a la Embajada británica en Irán Una multitud de manifestantes enojados se reunieron frente a la embajada británica en la calle Ferdowsi. El sitio del ataqueFecha 29 de noviembre de 2011Lugar Teherán, IránCoordenadas 35°41′46″N 51°25′08″E / 35.6962, 51.4188Partes enfrentadas Manifestantes iraníes Embajada de Reino Unido en Teherán Saldo ~20 protestantes iraníes (heridos)~3 oficiales británicos (heridos) [editar datos en Wikidata] El ataque a ...

 

Javi MorenoNazionalità Spagna Altezza178 cm Peso78 kg Calcio RuoloAllenatore (ex attaccante) Termine carriera1º novembre 2009 - giocatore CarrieraGiovanili 1994-1995 Barcellona Squadre di club1 1995-1996 Barcellona B10 (5)1996-1997 Córdoba15 (0)1997 Yeclano16 (6)1997-1998 Alavés10 (1)1998-1999 Numancia38 (18)1999-2001 Alavés71 (30)2001-2002 Milan16 (2)2002-2004 Atlético Madrid29 (5)2004→  Bolton8 (0)2004-2005 Real Saragozza18...

 

Russian icon representing the Nicene Creed, 17th century Ecumenical creeds is an umbrella term used in Lutheran tradition to refer to three creeds: the Nicene Creed, the Apostles' Creed and the Athanasian Creed. These creeds are also known as the catholic or universal creeds.[1][2] These creeds are accepted by almost all mainstream Christian denominations in the West, including Lutheran, Reformed, Catholic, and Anglican.[1][2][3][4][5] M...

King who is above other kings; type of monarch For other uses, see High King (disambiguation). This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these messages) This article relies largely or entirely on a single source. Relevant discussion may be found on the talk page. Please help improve this article by introducing citations to additional sources.Find sources: High king – news · newspapers...

 

1607 popular uprising in England This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.Find sources: Midland Revolt – news · newspapers · books · scholar · JSTOR (March 2008) (Learn how and when to remove this message) The Midland Revolt was a popular uprising which occurred in the Midlands of England in 1607. Beginning in late...