2013-09-18 14:57:19 +00:00
|
|
|
|
---
|
2024-12-28 12:06:33 +00:00
|
|
|
|
filename: brainfuck.bf
|
2013-09-18 14:57:19 +00:00
|
|
|
|
contributors:
|
|
|
|
|
- ["Prajit Ramachandran", "http://prajitr.github.io"]
|
|
|
|
|
translators:
|
|
|
|
|
- ["Haydar KULEKCI", "http://scanf.info/"]
|
|
|
|
|
---
|
|
|
|
|
|
2013-09-20 11:19:16 +00:00
|
|
|
|
Brainfuck (normalde brainfuck olarak bütün harfleri küçük olarak yazılır.)
|
|
|
|
|
son derece minimal bir programlama dilidir. (Sadece 8 komut) ve tamamen
|
|
|
|
|
Turing'dir.
|
2013-09-18 14:57:19 +00:00
|
|
|
|
|
2024-11-30 20:48:28 +00:00
|
|
|
|
```bf
|
2013-09-20 11:19:16 +00:00
|
|
|
|
"><+-.,[]" (tırnak işaretleri hariç) karakterleri dışındaki her karakter
|
2013-09-18 14:57:19 +00:00
|
|
|
|
gözardı edilir.
|
|
|
|
|
|
2013-09-20 11:19:16 +00:00
|
|
|
|
Brainfuck 30,000 hücresi olan ve ilk değerleri sıfır olarak atanmış bir
|
|
|
|
|
dizidir. İşaretçi ilk hücreyi işaret eder.
|
2013-09-18 14:57:19 +00:00
|
|
|
|
|
2015-10-31 01:00:03 +00:00
|
|
|
|
Sekiz komut vardır:
|
2013-09-18 14:57:19 +00:00
|
|
|
|
+ : Geçerli hücrenin değerini bir artırır.
|
|
|
|
|
- : Geçerli hücrenin değerini bir azaltır.
|
|
|
|
|
> : Veri işaretçisini bir sonraki hücreye hareket ettirir(sağdaki hücreye).
|
|
|
|
|
< : Veri işaretçisini bir önceki hücreye hareket ettirir(soldaki hücreye).
|
|
|
|
|
. : Geçerli hücrenin ASCII değerini yazdırır (örn: 65 = 'A').
|
|
|
|
|
, : Bir girdilik karakteri aktif hücre için okur.
|
2013-09-20 11:19:16 +00:00
|
|
|
|
[ : Eğer geçerli hücredeki değer sıfır ise, ]ifadesine atlar.
|
2013-09-18 14:57:19 +00:00
|
|
|
|
Diğer durumlarda bir sonraki yönergeye geçer.
|
2013-09-20 11:19:16 +00:00
|
|
|
|
] : Eğer geçerli hücredeki değer sıfır ise, bir sonraki yönergeye geçer.
|
2013-09-18 14:57:19 +00:00
|
|
|
|
Diğer durumlarda, [ ifadesine karşılık gelen yönergelere döner.
|
|
|
|
|
|
|
|
|
|
[ ve ] bir while döngüsü oluşturur. Açıkça, dengeli olmalıdırlar.
|
|
|
|
|
|
2013-09-20 11:19:16 +00:00
|
|
|
|
Basit bir brainfuck programına göz atalım.
|
2013-09-18 14:57:19 +00:00
|
|
|
|
|
|
|
|
|
++++++ [ > ++++++++++ < - ] > +++++ .
|
|
|
|
|
|
|
|
|
|
Bu program 'A' karaterini ekrana basar. İlk olarak, #1'inci hücre 6'ya artırılır.
|
2013-09-20 11:19:16 +00:00
|
|
|
|
#1'inci hücre döngü için kullanılacaktır. Sonra, ([) döngüsüne girilir ve
|
|
|
|
|
#2'inci hücreye hareket edilir. #2'inci hücre 10 kez artırılır, #1'inci hücreye
|
|
|
|
|
geri dönülür. #1 hücresini bir azaltır. Bu döngü 6 kez gerçekleşir. (Bu 6 kez
|
2013-09-18 14:57:19 +00:00
|
|
|
|
azaltmak demektir, #1 hücresi 0 değerini alır ve bu noktada ] ifadesini atlar).
|
|
|
|
|
|
2013-09-20 11:19:16 +00:00
|
|
|
|
Bu noktada, biz #1 hücresindeyiz, değeri şu anda 0 ve #2 hücresinin değeri
|
2013-09-18 14:57:19 +00:00
|
|
|
|
60'tır. Biz #2 hücresine hareket diyoruz ve bu hücreyi 5 defa artırıyoruz.
|
2013-09-20 11:19:16 +00:00
|
|
|
|
#2'nin şu anki değeri 65 olur. Sonra #2 hücresinin ASCII karşılığını
|
|
|
|
|
yazdırıyoruz. 65 değerinin ASCII karşılığı 'A'dır. Ekrana 'A' yazılacaktır.
|
2013-09-18 14:57:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
, [ > + < - ] > .
|
|
|
|
|
|
|
|
|
|
Bu program kullanıcıdan bir girdi okur, ve karakteri bir diğer hücreye yazdırır,
|
|
|
|
|
ve daha sonra aynı karakteri ekrana yazdırır.
|
|
|
|
|
|
2013-09-20 11:19:16 +00:00
|
|
|
|
, ifadesi kullanıcıdan karakteri #1 hücresine okur. Sonra bir döngü
|
|
|
|
|
başlar. #2 hücresine hareket edilir, #2 hücresinin değeri bir artırılır, #1
|
2013-09-18 14:57:19 +00:00
|
|
|
|
hücresine geri dönülür, ve #1 hücresinin değer bir azaltılır. Bu #1 hücresinin
|
2013-09-20 11:19:16 +00:00
|
|
|
|
değeri 0 olana kadar devam eder ve #2 hücresi #1'in eski değerini tutar. Çünkü
|
2013-09-18 14:57:19 +00:00
|
|
|
|
biz #1 hücresindeki verileri döngü süresince #2 hücresine taşıyoruz, ve sonunda
|
|
|
|
|
#2 hücresinin ASCII değerini yazdırıyoruz.
|
|
|
|
|
|
2013-09-20 11:19:16 +00:00
|
|
|
|
Boşluk karakteri sadece okunabilirliği artırmak içindir. Aşağıdaki gibi de
|
2013-09-18 14:57:19 +00:00
|
|
|
|
yazabilirsiniz.
|
|
|
|
|
|
|
|
|
|
,[>+<-]>.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Bu uygulamanın ne yaptığına bakalım:
|
|
|
|
|
|
2013-09-20 11:19:16 +00:00
|
|
|
|
,>,< [ > [ >+ >+ << -] >> [- << + >>] <<< -] >>
|
2013-09-18 14:57:19 +00:00
|
|
|
|
|
|
|
|
|
Bu program 2 sayı alır, ve birbiri ile çarpar.
|
|
|
|
|
|
2013-09-20 11:19:16 +00:00
|
|
|
|
Özetle, ilk olarak iki girdi alır. Sonra, #1 hücresinde şarta bağlı harici bir
|
2013-09-18 14:57:19 +00:00
|
|
|
|
döngü başlar. Sonra #2 ye hareket edilir, ve içerde #2 hücresine bağlı bir döngü
|
2013-09-20 11:19:16 +00:00
|
|
|
|
daha başlar ve #3 hücresinin değerini artırır. Ama, Bir problem vardır: iç
|
|
|
|
|
döngünün sonunda #2'inci hücrenin değeri 0 olacaktır. Bunu çözmek için #4
|
|
|
|
|
hücresinin de değerini yükseltiyoruz, ve sonra #4 hücresinin değerini #2'ye
|
2013-09-18 14:57:19 +00:00
|
|
|
|
kopyalıyoruz.
|
|
|
|
|
```
|
|
|
|
|
|
2013-09-20 11:19:16 +00:00
|
|
|
|
İşte brainfuck. Zor değil değil mi? Eğlenmek için kendi programınızı
|
|
|
|
|
yazabilirsiniz, veya farklı bir dilde brainfuck yorumlayıcısı yazabilirsiniz.
|
|
|
|
|
Yorumlayıcı oldukça basittir, ama mazoşist iseniz, brainfuck içerisinde bir
|
|
|
|
|
brainfuck yorumlayıcısı yazmayı deneyebilirsiniz.
|