Regular Expression (RegExp) – Düzenli Deyimler, İfadeler

Automata (otomat) Dersinin önemli konularından
birisi olan regular expressions kavramı, tanımlı olan dilde
üretilebilecek olan ifadelerin gösterim biçimidir.

Regular
expressions, constantlardan (sabitler) ve operatörlerden (operators)
oluşan kelimeler kümesi ve bu kelimeler kümesi üzerinde tanımlı
işlemlerdir. Sonlu bir alfabede Σ ‘de aşağıdaki sabitler ( constant )
tanımlıdır.

* (boş küme) ∅ kümenin boş olduğunu gösterir ve ∅ sembolü ile gösterilir
* (boş kelime) ε , {ε} kümesi şeklinde gösterilir
* (değişmez (literal) harf (charachter) ) dil kümesi Σ için {a} kümesi “a” harfini içerir.

Yukarıdaki bu dil için tanımlı işlemler aşağıda verilmiştir:

* ( üleştirme (concatenation) ) RS gösterimi { αβ | α, R için ve β, S için} kümesi şeklinde ifade edilir. Örneğin {“ab”, “c”}{“d”, “ef”} = {“abd”, “abef”, “cd”, “cef”}.
* ( alternation (değişim veya seçim) ) R|S gösteirmi R S lerin birleşim kümesini ifade eder.
* (Kleene star) R*
şeklinde ifade edilir ve R kümesindeki bütün concatenation (üleştirme)
ihtimallerinin oluşturduğu kümeye denilir. Bu kümeye ε dahildir.
Örneğin, {“ab”, “c”}* = {ε, “ab”, “c”, “abab”, “abc”, “cab”, “cc”,
“ababab”, … }.

Bazı kitaplarda | sembolü yerine + V veya U sembolleri de kullanılabilir.

Örnekler:

* a|b* -> {ε, a, b, bb, bbb, …}
* (a|b)* gösterimi , a ve b sembollerinden oluşabilecek bütün kelimeleri ifade eder.
* b*(ab*)* yukarıdaki örnek ile aynı sonucu verir
* ab*(c|ε)
gösterimi, a kelimesi ile başlayan, ve sıfır veya istenilen miktarda b
içeren son olarak da ister c ister ε ile biten kelimeleri ifade eder.
* (aa|ab(bb)*ba)*(b|ab(bb)*a)(a(bb)*a|(b|a(bb)*ba)(aa|ab(bb)*ba)*(b|ab(bb)*a))*

gösterimi, a ve blerden oluşan ve çift sayıda a veya tek sayıda b içeren kelimeleri ifade eder.

Bu yazıyı beğendiyseniz, başkalarının da ilgisini çekebilirsiniz:


444 views

2 responses to “Regular Expression (RegExp) – Düzenli Deyimler, İfadeler”
  1. nurhan says:

    1.(ab)* ={εε, ab,…}. bu ifadede “abab” olmaz tüm a’lar b’lerden önce gelmeli demişiz. tüm a’ların b’lerden önce gelmesi arada | (OR) olmamasından dolayı bu “AND” işlemidir. ve a’ların öncelikli olması AND kuralından mı geliyor?
    2.(ab*)* = ? (slaytınızda bu ifade geçiyor. bunun eşiti nedir bulamadım.

  2. Bu bahsettiğinizi nerede demişim? Ders sunumuna ve yukarıdaki konu anlatımında böyle bir ifade yok. Farklı ve benim bilmediğim bir yerde mi geçiyor?
    Bu yorumunuzdaki ifade hatalı
    (ab)* gösterimi, istenildiği kadar ab tekrarını ifade der.
    (ab)* = {ε,ab,abab,ababab,…} şeklindeki kümedir ve “abab” ifadesi elbette bu düzenli ifade tarafından içerilir. Bu ifadeden “tüm a’ların b’lerden önce gelmesi” gibi bir yorum yapılamaz.
    2. sorunuz için, sanırım slaytta geçenleri buraya yanlış almışsınız. Bahsettiğiniz ifade yanlış anlamadıysam:
    (a|b)* = b*(ab*)* olacak. Bu iki ifade birbirine eşittir denilmiş slaytta.

    başarılar

Leave a Reply


beş * = 25

Benzer Yazılar:

Bilgisayar Kavramları üzerinde şu anda okumakta olduğunuz 'Regular Expression (RegExp) – Düzenli Deyimler, İfadeler' isimli yazı 14 Apr 2007 tarihinde, saat: 03:23 'de �adi Evren �EKER tarafından gönderilmiş, toplam444 defa okunmuştur.

Benzer yazıları Bilgisayar Matematiği, Programlama Dilleri, Temel Bilimler kategorilerinden okuyabilirsiniz. Yazar ile irtibat kurmak için email gönderebilirsiniz. Yazıya yorum yapabilir ya da yapılan yorumları RSS 2.0 ile takibe alabilirsiniz.


Category: Bilgisayar Matematiği, Programlama Dilleri, Temel Bilimler