SEN2212 Data Structures and Algorithms IIBahçeşehir ÜniversitesiAkademik Programlar YAZILIM MÜHENDİSLİĞİÖğrenciler için Genel BilgiDiploma EkiErasmus BeyanıUlusal YeterliliklerBologna Komisyonu
YAZILIM MÜHENDİSLİĞİ
Lisans TYYÇ: 6. Düzey QF-EHEA: 1. Düzey EQF-LLL: 6. Düzey

Ders Tanıtım Bilgileri

Ders Kodu Ders Adı Yarıyıl Teorik Pratik Kredi AKTS
SEN2212 Veri Yapıları ve Algoritmalar II Bahar 2 2 3 7

Temel Bilgiler

Öğretim Dili: İngilizce
Dersin Türü: Must Course
Dersin Seviyesi: LİSANS
Dersin Veriliş Şekli: Yüz yüze
Dersin Koordinatörü: Dr. Öğr. Üyesi BETÜL ERDOĞDU ŞAKAR
Dersi Veren(ler): Dr. Öğr. Üyesi BETÜL ERDOĞDU ŞAKAR
Dr. Öğr. Üyesi YÜCEL BATU SALMAN
Arş.Gör. SEVGİ CANPOLAT
Arş.Gör. MERVE ARITÜRK
Opsiyonel Program Bileşenleri: Yok
Dersin Amacı: Bu dersin amacı yazılım mühendisliğinde kullanılan veri yapıları ve algoritmalarını detaylı incelemektedir. Dersin bitiminde öğrenci, ağaçlar, ikili arama ağaçları, dengeli ağaçlar, öbek ve çizge gibi veri yapılarının uygulaması, gerçekleştirilmesi ve analizi hakkında bilgi sahibi olacaktır. Sıralama, özetleme ve açgözlü algoritmalar öğretilecektir.

Öğrenme Kazanımları

Bu dersi başarıyla tamamlayabilen öğrenciler;
Bu dersi başarıyla tamamlayabilen öğrenciler;
1) Temel nesne yönelimli programlama ilkelerini açıklayabilir ve uygulayabilir.
2) Ağaçlar, ikili arama ağaçları, dengeli ağaçlar, öbek ve çizge gibi temel veri yapılarını gerçekleyebilir ve kullanılabilir.
3) Temel veri yapılarında sıralama işlemini gerçekleştirebilir.
4) Temel veri yapılarında arama işlemini gerçekleştirebilir.
5) Özetleme algoritmalarını gerçekleyebilir ve kullanabilir.
6) Açgözlü algoritmaları gerçekleyebilir ve kullanabilir.
7) Performanslı programlar geliştirebilmek için uygun veri yapılarını seçebilir ve geliştirebilir.

Dersin İçeriği

Dersin içeriği ağaçlar, ikili arama ağaçları, dengeli ağaçlar, öbek, çizge gibi temel veri yapıları ve sıralama, özetleme ve açgözlü algoritma konularından oluşmaktadır.

Haftalık Ayrıntılı Ders İçeriği

Hafta Konu Ön Hazırlık
1) Giriş ve Sıralama Algoritmaları. Sıralama algoritmaları.
2) Farklı ağaç yapılarına giriş. Ağaçlar.
3) İkili arama ağaçlarına giriş. İkili arama ağacı.
4) İkili arama ağacının Java ile kodlanması. İkili arama ağaçları.
5) Dengeli ağaçlara giriş ve AVL dengeli ağacının Java ile kodlanması. AVL ağaçlar.
6) Diğer dengeli ağaç türlerinin kullanımı. Diğer dengeli ağaçlar.
7) Öbek yapısının kullanımı ve Java ile kodlanması. Öbek.
8) Öbeklerinin öncelikli kuyruk olarak kullanılması. Arasınav. Öbek.
9) Özetleme algoritmalarının analizi ve kodlanması. Özetleme algoritmaları.
10) Çizge yapısının analizi ve kodlanması. Çizge.
11) Çizge algoritmalarının analizi ve kodlanması. Çizge algoritmaları.
12) Açgözlü algoritmaların analizi ve kodlanması. Açgözlü algoritmalar.
13) Açgözlü algoritmaların analizi ve kodlanması. Quiz. Açgözlü algoritmalar.
14) Tekrar.

Kaynaklar

Ders Notları / Kitaplar: Data Structures & Problem Solving Using Java (Mark Allen Weiss)
Data Structures and Algorithm Analysis in Java (Mark Allen Weiss)
Data Structures and Abstractions with Java (Frank Carrano)
Diğer Kaynaklar: Yok.

Değerlendirme Sistemi

Yarıyıl İçi Çalışmaları Aktivite Sayısı Katkı Payı
Uygulama 4 % 10
Küçük Sınavlar 1 % 10
Projeler 1 % 15
Ara Sınavlar 1 % 25
Final 1 % 40
Toplam % 100
YARIYIL İÇİ ÇALIŞMALARININ BAŞARI NOTU KATKISI % 45
YARIYIL SONU ÇALIŞMALARININ BAŞARI NOTUNA KATKISI % 55
Toplam % 100

AKTS / İş Yükü Tablosu

Aktiviteler Aktivite Sayısı Süre (Saat) İş Yükü
Ders Saati 14 2 28
Laboratuvar 14 2 28
Sınıf Dışı Ders Çalışması 12 2 24
Proje 10 2 20
Ödevler 2 5 10
Küçük Sınavlar 5 2 10
Ara Sınavlar 5 3 15
Final 10 3 30
Toplam İş Yükü 165

Program ve Öğrenme Kazanımları İlişkisi

Etkisi Yok 1 En Düşük 2 Düşük 3 Orta 4 Yüksek 5 En Yüksek
           
Dersin Program Kazanımlarına Etkisi Katkı Payı
1) Karmaşık mühendislik problemlerine yönelik yazılım proje, süreç ve ürünlerine ait fonksiyonel ve fonksiyonel olmayan özellikleri tanımlayabilmek. 4
2) Karmaşık mühendislik problemlerinde yazılım mimarisi, bileşenleri, ara yüzleri ve sisteme ait diğer alt bileşenleri tasarlayabilmek. 2
3) Kodlama, doğrulama, sınama ve hata ayıklama konularını da içerecek şekilde karmaşık yazılım sistemleri geliştirebilmek. 5
4) Karmaşık mühendislik problemlerinde yazılımı, programın davranışlarını beklenen sonuçlara göre sınayarak doğrulayabilmek. 2
5) Karmaşık yazılım sistemlerinin çalışması sırasında, çalışma ortamının değişmesi, yeni kullanıcı istekleri ve yazılım hatalarının ortaya çıkması ile meydana gelen bakım faaliyetlerine yönelik işlemleri yapabilmek. 1
6) Karmaşık yazılım sistemlerinde yapılan değişiklikleri izleyebilmek ve kontrol edebilmek, entegrasyonunu sağlayabilmek, yeni sürümlerini sistematik olarak planlayabilmek ve riskleri yönetebilmek. 3
7) Disiplin içi ve disiplinler arası takımlarda görev alarak karmaşık yazılım sistemleri yaşam süreçlerini tanımlayabilmek, değerlendirebilmek, ölçebilmek, yönetebilmek ve uygulayabilmek. 1
8) Karmaşık mühendislik problemlerinde gerçekçi kısıtlar ve koşullar altında yazılım gereksinimlerini toplama, yazılımı tasarlama, geliştirme, sınama, bakımını yapma konularındaki çeşitli araçları ve yöntemleri kullanabilmek. 2
9) Temel kalite metrikler tanımlayabilmek, yazılım yaşam döngüsü süreçlerini uygulayabilmek, yazılım kalitesini ölçebilmek, kalite model karakteristiklerini tanımlayabilmek, standartları uygulayabilmek ve bunları karmaşık yazılım sistemlerini analiz etmekte, tasarlamakta, geliştirmekte, doğrulamakta ve sınamakta kullanabilmek. 3
10) Yazılım mühendisliği ile ortak sınırlara sahip olan matematik, fen bilimleri, bilgisayar mühendisliği, endüstri mühendisliği, sistem mühendisliği, ekonomi, yönetim ve sürdürülebilir kalkınma gibi diğer disiplinler hakkında teknik bilgi kazanabilmek ve bunlar aracılığıyla yenilikçi fikirleri karmaşık mühendislik problemlerinde ve girişimcilik faaliyetlerinde kullanabilmek. 3
11) Yazılım mühendisliği kültürü ve etik anlayışını kavrayabilmek ve bunları yazılım mühendisliğinde uygulayabilecek temel bilgilere sahip olmak, meslek hayatı boyunca gerekli teknik becerileri öğrenip başarıyla uygulayabilmek. 2
12) Yabancı dil ve Türkçe kullanarak etkin rapor yazabilmek ve yazılı raporları anlayabilmek, tasarım ve üretim raporları hazırlayabilmek, etkin sunum yapabilmek, açık ve anlaşılır talimat verebilmek ve alabilmek. 4
13) Mühendislik uygulamalarının evrensel ve toplumsal boyutlarda sağlık, çevre ve güvenlik üzerindeki etkileri ve çağın mühendislik alanına yansıyan sorunları ile mühendislik çözümlerinin hukuksal sonuçları hakkında bilgi sahibi olmak.