Archive

You are currently browsing the archives for the Algoritma category.

Kas

4

Bubble Sort (Bora Usulu Bubble Sort )En Kısa Sıralama Algoritması

By Hüseyin Bora

C/C++ Balon Sıralama Bubble Sort

Amaç

Sırasız, karışık tek boyutlu bir tam sayı dizisini, küçükten büyüğe doğru sıralamak.

void sort(int *Array,int n)
{
for(int i=n-1 ;i>2;i–)
for(int j=0;j<i;j++)
(Array[j]>Array[i])?Array[j]^=Array[i]^=Array[j]^=Array[i]:0;
}

Tabiki kısa olması hızlı olması anlamına gelmiyor. Yinede Quick Sort hızlı çalışacaktır..

Kas

4

Sınıf Kilitlemesi Sınıflar Arası Döngüler

By Hüseyin Bora

Sınıf Kilitlemesi Sınıflar Arası Döngüler

Loop deyimleri kullanılmadan sadece iki sınıf kullanarak bir döngü oluşturula bileceğini biliyor muydunuz?  OPP mekanizması yanış kullanıldığında sistemi aşırı yorabilir.

Aşağıdaki iki sınıf kurucu metotlarında bir birlerini örneklerler A sınıfı kurucu metodunda B sınıfını örekler B sınıfı da kurucu metodunda A sınıfını bu sayede sonsuza uzayan bir döngü oluşturulur ve sistemin kilitlenmesine neden olur.

Dikkat aşağıdaki sınıflar sisteminin kilitlenmesine neden olabilir

class A{

var $b;
function A()
{
$this->b = new B();
echo "<br>A";
}
}
Class B{

var $a;
function B()
{
$this->a= new A();
echo "<br>B";
}
}

new A();

Sınıflara static durağan bir üye eklenerek ve sınıflardan birinde if ile kontrol edilerek bu problem aşılabilir. Aşağıda A ve B sınıflarının her birinden 10 ar adet oluşturan örnek

class A
{

static $say=0;

var $b;
function A()
{
A::$say++;
$this->b = new B();
echo "<br>A ".A::$say;
}
}
class B{

var $a;
function B()
{

if(A::$say!=10)
$this->a= new A();
echo "<br>B ".A::$say;
}
}

new A();