Masonlar.org - Harici Forumu

Masonluk Bilgidir. Bilimdir. Ilimdir. => Teknoloji => Programlama => Konuyu başlatan: Servan - Ağustos 20, 2011, 01:49:29 öö

Başlık: Algoritma Nedir ?
Gönderen: Servan - Ağustos 20, 2011, 01:49:29 öö
Algoritma, bir işin hangi etaplardan geçilerek yapılacağını gösteren çalışma planıdır. Algoritma bir programlama dili değildir. Programlama dillerine yol gösteren bir yöntem dizisidir. Her dilde algoritma yazılıp uygulanabilir. Örneğin bir cep telefonunun el kitapçığında yazan, rehber kaydı girmek için izlenecek yollar, o işin algoritmasıdır.
Algoritma yazarken, programın çalışması için kullanılan kaynakların, yapılması gereken kontrollerin veya işlemlerin açıkça ifade edilmesi gerekir. Ayrıca iyi bir algoritma, tüm ihtimalleri kontrol edip istenmeyen durumlarda ne yapılması gerektiğini belirtmesi gerekir.
Örneğin, bir e-ticaret uygulamasında ürün satış algoritması çıkarılır. Satın alınacak ürün seçildikten sonra, kullanıcıdan adet miktarı bilgisi alınır. Uygulama yazılırken, bu değerin Int16 veri tipinde olacağına karar verildiği düşünülürse; kullanıcının girdiği adet miktarı bu değişkene atanmadan önce kontrol edilmelidir. Eğer Int16 veri tipinin tutamayacağı bir değer girilmişse, çalışma anında uygulamanın beklenmedik şekilde durduğu ya da istenmeyen sonuçların üretildiği gözlemlenir. Ayrıca sistemin verdiği hata, kullanıcının anlamayacağı bir mesaj içereceği için, uygulamanın imajını da kötü yönde etkiler.
Veri girişi: Çalışma zamanında çoğu zaman, işleyişin tamamlanması için dışarıdan bir bilgi girilmesi gerekir. Algoritmanın çalışması için ihtiyaç duyduğu veriler, işlemi başlatan kişiden veya belirtilen bir kaynaktan alınabilir. Bu bilgiler sağlanmadan işlem devam etmez.
Kararlar: Karar ve kontrol yapıları algoritmanın akışını yönlendiren en önemli kavramlardır. Girilen veya işlem sonucunda elde edilen veriler, işlemin amacına göre kontrol edilir ve sonuca göre algoritma akışı istenilen yere yönlendirilir.
İşlemler: Algoritmanın akışı boyunca veriler üzerinde değişiklikler, yeni değer atamaları gibi işlemlere ihtiyaç duyulur. Algoritmalar kurulurken, yapılan işlemlerin yalın halde, tek tek yazılması okunabilirliği arttırır.
Algoritmalar adım sırası ile çalışır ve karar yapıları sonucunda farklı bir yere yönlendirilmediği müddetçe, bir sonraki adım ile işlemeye devam eder.
Örnek: Telefon kulübesinden telefon açmak için örnek bir algoritma
1. Telefon kulübesine git
2. Telefon kartı al
3. Telefon sırasında kaç kişi olduğuna bak
4. Kişi sayısı sıfırdan fazlaysa 3 e dön
5. Kapı kapalıysa kapıyı aç
6. İçeri gir, kapıyı kapat
7. Telefon kartını telefona yerleştir
8. Ahizeyi kaldır
9. Numarayı çevir
10. Konuşmanın bitip bitmediğine bak
11. Konuşma bittiyse kartı al, bitmediyse 10 a dön
12. Bir daha konuşma yapılacaksa 7 e dön
13. Kapıyı aç, dışarı çık
Bu algoritmanın işlemesi için, her ihtimal gözden geçirilerek, algoritma akışı gerekli yerlere yönlendirilir. Örneğin kapının kapalı olması durumunda kapıyı açmak için gerekli komutlar verilmelidir. Bu algoritmanın ihtiyaç duyduğu veriler, ya kullanıcı tarafından verilir ya da işlem başlamadan önce belirlidir. Sıradaki kişi sayısı, telefon kartı gibi veriler kullanıcı tarafından sağlanmış; çevrilecek numara, algoritma başlamadan önce belirlenmiştir.

Başlık: Ynt: Algoritma Nedir ?
Gönderen: Masor1976 - Ağustos 20, 2011, 09:55:13 öö
Eski anılarımı canlandırdınız Sayın Servan.

1995-97 yılında bilgisayar programcılığı okumuştum. 286 pc ler vardı. Harddisk yoktu makinelerde. Diskete sığabildiği kadar ms-dos, pascal, c, clipper, dbase gibi dilleri görmüştük. Staj yaptığım yerde windows 98 i görünce özellikle de quake adlı oyunu, ufo görmüş gibi şaşırmıştım. Yazılım ve donanım dünyası gerçekten de hayal sınırlarını aşmış durumda.

Temel dosyalama metoduyla pascalda ve c dilinde örneğin bir sınıfın öğrencilerini ve öğrencilerin vize final sınavlarını takip eden, bütünlemeye kalanları listeleyebilen  vb. veri takip programı yazardık okulda. Bu dönemde hocamız bize pascal da binary data tipinin yaratılması veri aktarımı konularını işlemiş sadece bu binary data tipindeki yaratılan veriden veri silmeyi okul bitirme ödevi olarak vermişti. Bir kaç hafta uğraştık fakat kafam basmıyordu. 1000-1500 sayfalık pascal ve delphi kitaplarında da yoktu. Eski kitapçılarda bulduğum incecik bir pascal kitabında iki ünlü rus matematikçinin yazdığı kodu buldum. İlginçtir sadece binary data tipinden dosya silme metodu vardı. Ben o kodu alıp öğrenci takip yapısına uyarlamam 3 haftamı aldı fakat sonuçta kod çalıştı. Sınıfı bütünlemeye kalmadan sadece ben geçmiştim :) Fakat hala bu data tipininden veri silmeyi aklım alabilmiş değil. Bunun temel nedeni de kendi kendini çağıran fonksiyonlardan oluşmasıydı. Bu kendi kendini çağıran fonksiyon meselesi insanın beynini oldukça zorluyor.

Şimdi bakıyorum Oracle ve Sql gibi veri tabanı motorlarına bir kaç kod yazarak olağan üstü hızda veri tarama yapılabiliyor. Örneğin klasik dosyalama metodunda ortalama 5000 veriden oluşan bir veri bankasında veri arattığınızda yazdığınız program aradığınız veriyi bulmak için saatlerce donuyordu. Şimdi örneğin facebookda yüzmilyonlarca insanın verileri saliseler içinde veri aktarımı yapıyor. Hakikaten de aklım almıyor.

Saygılarımla.
Başlık: Ynt: Algoritma Nedir ?
Gönderen: Servan - Ağustos 21, 2011, 01:19:54 öö
Eski anılarımı canlandırdınız Sayın Servan.

1995-97 yılında bilgisayar programcılığı okumuştum. 286 pc ler vardı. Harddisk yoktu makinelerde. Diskete sığabildiği kadar ms-dos, pascal, c, clipper, dbase gibi dilleri görmüştük. Staj yaptığım yerde windows 98 i görünce özellikle de quake adlı oyunu, ufo görmüş gibi şaşırmıştım. Yazılım ve donanım dünyası gerçekten de hayal sınırlarını aşmış durumda.

Temel dosyalama metoduyla pascalda ve c dilinde örneğin bir sınıfın öğrencilerini ve öğrencilerin vize final sınavlarını takip eden, bütünlemeye kalanları listeleyebilen  vb. veri takip programı yazardık okulda. Bu dönemde hocamız bize pascal da binary data tipinin yaratılması veri aktarımı konularını işlemiş sadece bu binary data tipindeki yaratılan veriden veri silmeyi okul bitirme ödevi olarak vermişti. Bir kaç hafta uğraştık fakat kafam basmıyordu. 1000-1500 sayfalık pascal ve delphi kitaplarında da yoktu. Eski kitapçılarda bulduğum incecik bir pascal kitabında iki ünlü rus matematikçinin yazdığı kodu buldum. İlginçtir sadece binary data tipinden dosya silme metodu vardı. Ben o kodu alıp öğrenci takip yapısına uyarlamam 3 haftamı aldı fakat sonuçta kod çalıştı. Sınıfı bütünlemeye kalmadan sadece ben geçmiştim :) Fakat hala bu data tipininden veri silmeyi aklım alabilmiş değil. Bunun temel nedeni de kendi kendini çağıran fonksiyonlardan oluşmasıydı. Bu kendi kendini çağıran fonksiyon meselesi insanın beynini oldukça zorluyor.

Şimdi bakıyorum Oracle ve Sql gibi veri tabanı motorlarına bir kaç kod yazarak olağan üstü hızda veri tarama yapılabiliyor. Örneğin klasik dosyalama metodunda ortalama 5000 veriden oluşan bir veri bankasında veri arattığınızda yazdığınız program aradığınız veriyi bulmak için saatlerce donuyordu. Şimdi örneğin facebookda yüzmilyonlarca insanın verileri saliseler içinde veri aktarımı yapıyor. Hakikaten de aklım almıyor.

Saygılarımla.

Teknoloji gelişiyor Sayın Masor1976 ;

:) teknolojik gelişmeler çok hızlı değişim içerisindeler şimdilerde microsoft yeni veri tabanları geliştiriyor ama bunları hala açıklamış değiller

Saygılarımla
Başlık: Ynt: Algoritma Nedir ?
Gönderen: Felix Steiner - Ağustos 25, 2011, 11:04:02 ös
Algoritma hayatımızın ta kendisi de denilebilir bence :) Zaten telefon kulübesi örneği de çok canlı bir örnek olmuş. Ben algoritmanın anlamını, "çay nasıl demlenir?" sorusunun üstünden öğrenmiştim :)  :)
Şaka bir yana, bilgisayar programlamanın olmazsa olmazı. Bir program yazacakken, harcanacak zamanın gerekirse %60-%70'ini buraya ayırmak en doğrusu. Satranç oynamak da algoritma oluşturabilme yetimizi arttırıyor. Yani olasılıklar üzerinde ne kadar uğraşırsak, o kadar güzel ve düşük maliyetli-yüksek performanslı algoritmaları ortaya çıkarabiliriz.
Saygılarımla