29 Kasım 2011, 11:56 | #1 | |
Çevrimdışı
Kullanıcıların profil bilgileri misafirlere kapatılmıştır.
IF Ticaret Sayısı: (0) | Ağaç Yapıları(Tree structures) Ağaç yapılarına, hiyerarşik yapıda düğümlerin(node) bulunduğu sonlu düğümler kümesidir diyebiliriz. Kök(root) düğüm dışındaki tüm düğümler de aynı zamanda her biri alt ağaç olarak adlandırılan ağaç özelliğinde küme oluşturabilirler. Her ağaç kümesi düğümlerden ve kenarlardan(edge) oluşur. Her node bir veriyi tutar. Kenarlar da iki ayrı düğümü birbirine bağlar. Her ağaç mutlaka kökten oluşur. Ve çocuk node'lara sahip olabilir, bu çocuk node'lara aynı zamanda leaf(yaprak) de denir. Seviye(level), alta doğru düşündüğümüzde iki node arasındaki mesafedir. Mesela resimde görmüş olduğunuz ağaç yapısının seviyesi 2'dir. İkili ya da binary tree yapısını birçoğunuz duymuşsunuzdur. Özellikle aramalarda kullanılır. Bu tür ağaç yapılarında kök olarak adlandırılan özel bir düğüm vardır. Her düğüm en fazla iki düğüme bağlıdır. Kök dışında her düğüm bir daldan gelmektedir. Tüm düğümlerden yukarı doğru çıkıldıkça kök düğüme ulaşılır. Yukarıda seviyeden(level) bahsetmiştim, Derinlik ise seviyeden bir fazla olur. Yani resimdeki ağaç yapısının derinliği 3'tür. Full binary tree'de her yaprak aynı derinliğe sahiptir.Yaprak olmayan düğümlerin tümünün iki çocuğu olmalıdır. Bir full binary tree n adet yaprağa sahipse 2n-1 adet node olması gerekmektedir. Eğer herhangi bir ağacın her bir düğümü hiç bir çocuğa sahip değilse veya iki çocuğa sahipse bu ağaç yapısı proper binary tree olarak adlandırılır. Yani bu yapıda tek çocuk olmaz. Dengeli(balanced) binary tree, yüksekliği ayarlanmış ağaç yapılarıdır. Bütün düğümler için sol alt ağacın yüksekliği ile sağ alt ağacın yüksekliği arasında en fazla bir fark varsa bu dengeli ağaç olarak adlandırılır. Ağaçların sıralanış şekli: Preorder(ön ek), kök-sol-sağ. İnorder(iç ek), sol-kök-sağ. Postorder(son ek), sol-sağ-kök. Sıralama yapacağımız zaman; preorder isteniyorsa, ağaç yapısına bakılır, önce kök yazılır daha sonra sol ve sağ taraf taranır. İnorder ve ve postorderda da yapacağımız işlemler benzerdir. Örnek olarak resimdeki ağaç yapısını inorder'a göre sıralayacağımız zaman şu şekilde sıralarız: D-B-E-A-F-C-G İkili arama ağacı silme işleminde 3 farklı durum vardır. Eğer silenecek node, yapraksa silme işlemi gerçekleştirilir. Silinecek olan node çocuğa sahipse o düğümün işaretçi bilgisi o düğümün atasına yani parent'ına aktarılması gerekmektedir. Bunun işlem için iki yol vardır. Silinen düğüm yerine o düğümün sağ alt ağacındaki en küçük değerli düğüm getirilir. Veya silinen düğüm yerine sol alt ağacın en büyük değerli düğümü getirilir. Şimdi aşağıda bir örnek paylaşacağım, kod açıklamalarını kabataslak bir şekilde yanlarında belirttim. Kod: Kodu kopyalamak için üzerine çift tıklayın!
| |
|
Etiketler |
ağaç, structures, yapılarıtree |
Konuyu Toplam 1 Üye okuyor. (0 Kayıtlı üye ve 1 Misafir) | |
| |
Benzer Konular | ||||
Konu | Konuyu Başlatan | Forum | Cevaplar | Son Mesaj |
Ağaç Ev Resimleri, Ağaç Ev Fotoğrafları, Ağaç Ev Modelleri | Violent | Ev Dekorasyonu | 0 | 04 Aralık 2014 22:46 |
Ağaç Gifleri, Hareketli Ağaç Resimleri, Hareketli Ağaç Avatarları | Violent | Avatar ve Smiley | 0 | 06 Mart 2014 23:00 |
Ağaç Boası (Red Amazon Tree Boa) Latin America - Amazon | Sevda | Hayvanlar Alemi | 1 | 28 Temmuz 2013 13:24 |
Acı Ağaç - Acı Ağaç Nedir - Acı Ağaç Yetiştiriciliği | YapraK | Türkiye'nin Coğrafi Bölgeleri | 0 | 14 Mart 2010 21:21 |