Bu sitedeki yazıların tamamı F. Oğuz ÖZKEROĞLU isimli şahıs tarafından uydurulmuş bilgilerden oluşmaktadır.

İçeriği kullanmak için kimseden izin alınmasına gerek yoktur.

Mart 19, 2010

java

(Yorum yapılmamış)

Daha önceki Değişken Adında Türkçe Karakter Kullanımı [C#] yazımda bahsettiğim C#’taki değişken, class, namespace isimlerinde Türkçe karakter kullanabiliyor olmak “C#’ta varsa Java’da neden olmasın?” sorusunu kendime sormama ve neticesinde bu yazının yazılmasına vesile oldu.

Netbeans 6.8 ve Eclipse Galileo ile aynı şeyleri denedim ikisinde de sonuç aynı : C#’ın yaptığını Java da yapıyor; proje, package, class ve değişken isimlerinde Türkçe karakter kullanmak istendiğinde “Abi sen burda Türkçe karakter kullanmaya çalışıyorsun ama bunu yapamazsın, mümkünse onları İngilizce karşılıkları ile değiştir” falan demiyor.

O yazıdaki kodun yaklaşık Java karşılığı aşağıda :

package türkçekarakter;

public class TürkçeKarakterİçerenSınıf {
    public static void main(String[] args) {

        String strTürkçeKarakterİçerenDeğişken = "Değişkenin değeri.";
        System.out.println(strTürkçeKarakterİçerenDeğişken);
    }
}

Şu görseller de Netbeans ve Eclipse’teki proje ve konsol alanları :
Netbeans proje
Netbeans console
Eclipse proje
Eclipse console

Bize programlama derslerinde öğretilen “değişken isminde Türkçe karakter olmaz” artık kural olmaktan çıkıp gelenek haline geliyor sanırım.

Ocak 8, 2010

cSharp

5 yorum

Kodaman’da gördüm bugün merak ettim, Windows’u açıp baktım hakkatten de dedikleri gibi değişken isimlerinde Türkçe karakter kullanılabiliyormuş. Ordaki örneği aynen denedim. Ahanda kanıtı :

using System;

namespace TürkçeKarakterİçerenDeğişkenler
{
    class Program
    {
        static void Main(string[] args)
        {
            String strTürkçeKarakterİçerenDeğişken = "Türkçe karakter içeren değişkenin değeri.";
            Console.WriteLine(strTürkçeKarakterİçerenDeğişken);
            Console.Read();
        }
    }
}

Çıktı da şöyle görünüyor :

CSharp Türkçe Karakter

Şimdi bunu yaparak dünyayı mı kurtardık?

Hayır.

Ama olsun, fazla bilgi göz çıkarmaz.

Çomü yazılım seminerleri
Başkanlığını yaptığım Çomü Yazılım ve Otomasyon Topluluğu’nun bu yılki ilk etkinliği olan yazılım seminerlerine bugün başladım. Seminerlerin dönem sonuna kadar devam etmesini planlıyoruz. İlk gün başlangıç olarak topluluktan bir arkadaşımla birlikte, Bilgisayar ve Öğretim Teknolojileri Öğretmenliği bölümü 2. sınıf öğrencilerinden oluşan 30 kişilik bir gruba C++ programlama dilini kullanarak algoritma ve programlama anlattım. Derslerinde C++ programlama dilini daha önceden gördükleri için anlamaları hiç de zor olmadı ve konularda tekrara gerek kalmadan kolaylıkla ilerleyebildik.

Programlama dersi alan Fizik ve Matematik bölümlerinden gelen istek üzerine bir sonraki haftadan itibaren bir grup daha eklenmiş olacak ve dönem sonuna kadar Bilgisayar ve Öğretim Teknolojileri Öğretmenliği, Fizik ve Matematik bölümü öğrencilerine C++ ile programlama anlatmaya devam edeceğim.

Dersler sırasında yazdığımız kod örneklerini de seminer sayfasına her ders sonrası düzenli olarak ekleyeceğim. Dersleri kaçıran ya da kodları alamayan arkadaşlar burdan yararlanabilirler.

Eylül 11, 2009

algoritmalar, java

21 yorum

Daha önceki yazılarımdan birinde(Selection Sort) sıralama algoritmalarına küçük bir giriş yapmıştım. Bu yazı da onun devamı niteliğinde olacak ama açıklama için yine işi daha iyi birilerine (Wiki) bırakacağım. Bubble sort için C/C++ ve Java’da yazdığım kodları yazmam yeterli olur sanırım.

Bu arada Java’da yazdığım kod sayısı 100 satırı geçti bunlarla birlikte :P “Hello World” un üstüne bayağı şey yapmışım demek ki :)

C/C++ Kodu :

void bubbleSort(int dizi[], int elemanSayisi)
{
     int temp;
     int i, j;

     for (i=1; i<elemanSayisi; i++)
     {
         for (j=0; j<elemanSayisi-i; j++)
         {
             if(dizi[j] > dizi[j+1])
             {
                        temp = dizi [j];
                        dizi [j] = dizi [j+1];
                        dizi [j+1] = temp;
             }
         }
     }
}

Java Kodu :

    public static void BubbleSort(int [] dizi)
    {
        int temp;   // Yer değiştirmede kullanılacak geçici değişken
        for (int i=1; i<dizi.length; i++)
        {
            for(int j=0; j<dizi.length-i; j++)
            {
                if (dizi[j] > dizi [j+1])
                {
                    temp = dizi [j];
                    dizi [j] = dizi [j+1];
                    dizi [j+1] = temp;
                }//Önce gelen elaman bir sonrakinden büyükse ikisi yer değiştiriyor
            }// Dizinin ardışık elamanlarını karşılaştırmak için kullandığımız döngü
        }// Her karşılaştırmadan sonra yeniden kaldığımız yerden devam etmemizi sağlayan döngü
    }

Mart 4, 2009

algoritmalar, java

1 yorum

Bilgisayar ortamında verilerin sıralı olması birçok işi kolaylaştırır. Arama, ekleme, bölme vs. durumlarında verilerin sıralı olması ile olmaması arasında çok büyük performans farkı olabilir.
Birçok algoritma (örneğin binary search) sıralı veriler üzerinde çalışır. Kullanıcı için de verilerin sıralı olması büyük kolaylık sağlar.
Verilerin sıralanması için birçok algortima geliştirilmiştir.

* Selection Sort
* Bubble sort
* Insertion sort
* Shell sort
* Merge sort
* Heapsort
* Quicksort
* Bucket sort
* Radix sort
* Distribution sort
* Shuffle sort

Listeyi uzatmak mümkün. Sıralanacak veririn boyutu, yazılacak kod maliyeti, sistem kaynakları, kullanıcı tercihi vb. durumlara göre herhangi biri tercih edilebilir.
Bunlardan Selection Sort’u inceleyelim. Sayı dizisini kullaracak olursak, algoritma ilk adımda tüm diziyi dolaşacak, en küçük elemanı bulup ilk sıraya yazacak.
Sonra dizinin kalan kısmında aynı işi yeniden yapacak. Kalan kısmı tarayıp en küçük elamanı bulup, ikinci sıraya yazacak. Bu şekilde son elemana kadar gidip en küçükten büyüğe doğru dizimiz sıralanmış olacak.

Viki’de aşağıdaki animasyonu buldum, Selection Sort için hazırlanmış basit bi şey.

Selection Sort

Fonksiyon için de C ve Java’da aşağıdaki kodları yazdım. Aynı işi yapan benzer şeyler de yazılabilir.

C/C++ kodu :

void selectionSort (int dizi[], int elemanSayisi)
{
     int i, j, enKucuk, temp;
     for (i=0; i<elemanSayisi-1; i++)
     {
         enKucuk = i;
         for (j=i+1; j<elemanSayisi; j++)
         {
             if (dizi[j] < dizi [enKucuk])
             enKucuk = j;
         }
         temp = dizi[i];
         dizi[i] = dizi[enKucuk];
         dizi[enKucuk] = temp;
     }
}

Java kodu :

    private static void selectionSort(int [] dizi,int n)
    {
        int temp;
        int enKucuk;
        for(int i=0; i<n-1; i++)
        {
            enKucuk=i;
            for(int j=i; j<n; j++)
            {
                if (dizi[j] < dizi[enKucuk]) enKucuk=j;
            }
            temp=dizi[i];
            dizi[i]=dizi[enKucuk];
            dizi[enKucuk]=temp;
        }
    }

Fonksiyon argüman olarak aldığı diziyi Selection Sort algoritması ile sıralıyor.

İç içe iki tane döngü kullanıldığı için algoritmanın karmaşıklığı O(n²) olur. Küçük boyutlu dizilerde fazla kod yazmaya gerek kalmadan kullanılabilecek bir algoritmadır.

Şubat 14, 2009

cSharp

3 yorum

14 Şubat sevgililer günü anısına C# ile basit bir uygulama yazdım. Uygulama çalışmaya başladığında ekrana aşağıdaki gibi küçük bir pencere geliyor, kullanıcı hayır dediği sürece yeniden başlatıyor kendini.

Benimle evlenir misin?

Evet butonuna tıklandığında ise camdan bir gül resmi ekranı kaplıyor.

Evlenme teklifi tabi ki çok özel olmalı, benim bunu yapma amacım sadece can sıkıntısı..

Dil olarak C#,  IDE olarak Visual Studio 2008 kullandım. Çalıştırılabilir dosyaya burdan, yazdığım class’a burdan ulaşabilirsiniz. Çalışması için bilgisayarda .net framework kurulu olmalıdır.

Ocak 27, 2009

cSharp, php, projeler

4 yorum

Herkesin bildiği sayısal loto var bu yazımda.
Kazanmak için 1 – 49 arası sayılardan doğru olanları önceden tahmin etmek gerekiyor.

Çoğu insanın uğurlu sayıları vardır. Bazılarının bir tane, bazılarının da birkaç tane. Eğer bu sayılar 1 – 49 aralığındaysa kuponunda o sayılara yer verenlerin sayısı azımsanmayacak kadar çok. Ama kazanmak için uğurlu sayınızın olması yetmiyor.

Ayrıca kupon doldururken yazdığımız diğer sayılardan etkileniriz. Mesela 37 ve 38 yazan biri genelde aynı kolonda 39 yazmaz. Oysa 1 – 12 – 23 – 34 – 45 – 49 ile 1 – 2 – 3 – 4 – 5 – 6 gelme olasılıkları aynıdır.

Birden fazla doldurduğumuzda yazacak sayı bulmakta zorlanırız bazen.

Kuponları otomatik dolduran makineler bu sorunlara (bunlardan harhangi birini sorun olarak görenlere) bir derece yardımcı oluyorlar.

Biz de C# ile bu makineler gibi sayı üretebiliriz. Bu konuda .net’in Random sınıfı bizim işimizi görecektir.

Önce Random sınıfından bir nesne yaratmakla başlayalım :

Random rnd = new Random();

ile Rondom sınıfından rnd isimli bir nesne yaratıyoruz.

int birinciSayi = rnd.Next(1, 50);

ile de 1-50 arasında (1 dahil 50 dahil değil) rastgele bir sayı üretiyoruz.

Daha sonra

int ikinciSayi = rnd.Next(1, 50);
while (birinciSayi == ikinciSayi)
{
     ikinciSayi = rnd.Next(1, 50);
}

satırları ile ikinci ratgele sayımızı üretip diğeri ile eşit mi diye kontrol ediyoruz. Eğer iki sayı eşitse while döngüsü yardımı ile, eşit olmayana kadar ikinci sayı yeniden üretiliyor.

Üçüncü sayı için de

int ucuncuSayi = rnd.Next(1, 50);
while (birinciSayi == ucuncuSayi || ikinciSayi == ucuncuSayi)
{
     ucuncuSayi = rnd.Next(1, 50);
}

bu kodları kullanalım. Bu da aynı şekilde üretilen üçüncü sayı ile ilk iki sayıyı karşılaştırıyor. Herhangi birine eşitse yeniden üretiyor.

Benzer şekilde 6 farklı sayıyı da ürettikten sonra istersek direkt kullanabilir, istersek sıraladıktan sonra kullanabiliriz. (Trt çekilişten sonra hemen sıralayıp veriyor :))

Sıralamak için sayıları bir diziye atıp, diziyi sıralayalım. Bunu :

int[] dizi = new int[6];
dizi[0] = birinciSayi;
dizi[1] = ikinciSayi;
dizi[2] = ucuncuSayi;
dizi[3] = dorduncuSayi;
dizi[4] = besinciSayi;
dizi[5] = altinciSayi;

şeklinde diziye atarak ve :

Array.Sort(dizi);

şeklinde de sıralayarak yapabiliriz. Sıralama yapmak için C’deki gibi kendi fonksiyonumuzu yazmak yerine Array sınıfının nimetlerinden yararlanmak daha kolay olur :)

Artık elimizde 1 – 49 arasında 6 farklı elemanı olan bir dizi var. Bundan sonrası size ait. Konsolda çalışıyorsanız :

for (int i = 0; i < 6; i++)
{
     Console.WriteLine(dizi[i]);
}

şeklinde sayıları görebilirsiniz. Eğer windows formu kullanacaksak forma 1 tane buton ve 6 tane text box eklememiz gerekecek.
Text kutularının isimlerini değiştirmezsek eğer, butonun click eventine :

textBox1.Text = Convert.ToString(dizi[0]);
textBox2.Text = Convert.ToString(dizi[1]);
textBox3.Text = Convert.ToString(dizi[2]);
textBox4.Text = Convert.ToString(dizi[3]);
textBox5.Text = Convert.ToString(dizi[4]);
textBox6.Text = Convert.ToString(dizi[5]);

bunları yazarsak, sayılarımız sıralı olarak her kutunun içinde bir tane olacak şekilde görünecektir.

Visual Studio 2008 ile derlediğim örnek uygulamayı burdan indirebilirsiniz.
Çalışması için bilgisayarınızda .net framework 2.0 veya üzeri kurulu olmalıdır.

Yukarıdaki işlerin aynısını Php ile de yapabiliriz. Sayıları Php kullanarak üretmek için şuraya göz atın.

Ocak 9, 2009

çalışmalar, php

13 yorum

Asal Sayı : 1 ve kendisinden başka tam böleni olmayan pozitif tamsayılara asal sayı denir. 2, 3, 5, 7, 37, 227.. gibi. Belli bir sayıları yoktur, sonsuzdurlar. Matematikçiler yüzyıllardan beri asal sayıları veren bi formül bulmak için uğraşıyorlar ama nafile. Bu hala çözülmeyi bekleyen en büyük problemlerden biri. Biz belki asal sayıları veren bi formül bulamayız ama php (ve daha birçok programlama dili) ile sayının asal olup olmadığını kontrol edebiliriz. Bunu çok basit olarak php’de :

function asalMi($sayi)
{
      $kok=sqrt($sayi);

      for ($i=2; $i<=$kok; $i++)
      {
           if($sayi % $i==0) return 0;
      }
      return 1;
 }
 

C’de de :

int asalMi(int sayi)
{
     int i;
     for (i=2; i<=sqrt(sayi); i++)
     {
          if (sayi%i==0) return 0;
     }
     return 1;
 }

şeklinde yapabiliriz. Sayımız 2′den, kendi kareköküne kadar olan sayılara teker teker bölünecek, eğer herhangi birine tam bölünüyorsa fonksiyon geriye 0 döndürecek (sayı asal değil), hiçbirine tam bölünmüyorsa fonksiyon geriye 1 değeri döndürecek (sayımız asal). Php ile örnek bir uygulama yazdım. Denemek isterseniz aşağıdaki kutucuğa 1 – 1.000.000 arası bir tamsayı yazıp, butona tıklayın. Scriptimiz 1′den yazdığınız sayıya kadar olan asal sayıları bulup ekrana yazacak. Not : 1.000.000′dan daha büyük değerler için bayağı kasıyor :)