Ana içeriğe atla

Bubble Sort - Baloncuk Sıralama Algoritması


Bu postta sıralama algoritmalarından olan buble sort yani baloncuk sıralama algoritması ile ilgili matlab kod satırları ve sıralamanın videosunu paylaşacağım.


Matlab Kodlarımız

clear all
clc

%biribirinden farklı 1'den 1000'e kadar 
%sayı dizisi oluşturma algortiması
sutun = 1001;
durum=1;
i=1;
while durum==1
    sayi(i)=round(2+(sutun-2)*rand());
    if i~=1
        s=i;
        while s~=1
            while sayi(s-1)==sayi(i)
                sayi(i)=round(2+(sutun-2)*rand());
                s=i;
            end
            s=s-1;
        end
    end
    if length(sayi)==sutun-1
        durum=0;
    end
    i=i+1;
end

%random sayılardan aynısının bulunup
%bulunmadıgını kontrol eder

for i=1:length(sayi)-1
    for j=i+1:length(sayi)
        if sayi(i)==sayi(j)
            'aynı sayı var, algoritma hatalı'
        end
    end
end
        
sayi=sayi-1;

y=1:length(sayi);
sayi2 = sayi;

%buble sort kısmı

tic()

for i=1:length(sayi)-1
    for j=i:length(sayi)
        if sayi(i)>sayi(j)
            temp = sayi(i);
            sayi(i) = sayi(j);
            sayi(j) = temp;
            pause(0.00001)
            bar(y,sayi);
        end
    end
end

toc()

Yorumlar

Bu blogdaki popüler yayınlar

Matlab Operatörler

Matematiksel operatörler: +  Toplama –  Çıkarma *  Çarpma /  Bölme ^  Üst alma .* Elemanter çarpım ./  Elemanter bölme .^  Elemanter üst alma a+b  Boyutları aynı olan a ve b matrisini toplar. a-b  Boyutları aynı olan a ve b matrislerinin farkını alır. a*b  Sütun sayısı m olan a matrisiyle satır sayısı m olan b matrisini çarpar. a/b  b düzenli kare bir matrisse (determinantı sıfırdan farklıysa), aynı boyutlu a matrisiyle; a*inv(b)işlemini yapar. a.*b  Boyutları aynı olan a ve b matrislerinin elemanlarını karşılıklı olarak çarpar. a./b  Boyutları aynı olan a ve b matrislerinin elemanlarını karşılıklı oranlar. sqrt  Kök alma abs  Mutlak değer rats  Kesirli gösterim Mantıksal operatörler: &  Ve |  Veya ~  Değil /  Bölme Karar operatörleri: >  Büyüktür <  Küçüktür >=  Büyük eşittir <=  Küçük eşittir ==  Eşittir ~= ...

2. Dereceden 1 Bilinmeyenli Denklemin Köklerini Buldurma - MATLAB

2. dereceden bir bilinmeyenli denklemin köklerini buldurmak için denklemin bilinmeyen katsayılarına ve sabit sayısına ihtiyacımız var. Kök buldurma denklemi aşagıdaki gibidir. Yapacagımız işlemleri daha iyi anlamanız için akış diyagramı aşagıda ki fotoğrafta görülmektedir Akış diyagramından yola çıkarak matlab kodlarıını adım adım yazalım. a=input(‘a= ’); %x^2nin katsayısını kullanıcıdan girmesini istiyoruz b=input(‘a= ’); %x in katsayısını kullanıcıdan girmesini istiyoruz c=input(‘a= ’); %c nin yani sabit sayının kullanıcıdan girmesini istiyoruz disp (‘ ’); %ekrana birazcık boşluk bırakıyoruz d=b * b - 4 * a * c; if (d > 0 ) disp (‘Gerçek İki Kök Vardır’); %ekrana kök bulunduğunu yazıyoruz x1=( - b - sqrt (d)) / ( 2 * a); %birinci kökü buluyoruz x2=( - b + sqrt (d)) / ( 2 * a); %ikinci kökü buluyoruz [yz,ht]=sprintf(‘ 1. Kök: %0.5f’,x1); disp(yz); %birinci kökü ekrana formatlı olarak yazdırıyoruz [yz,ht]=spri...