AKTS - Veri Yapıları

Veri Yapıları (CMPE226) Ders Detayları

Ders Adı Ders Kodu Dönemi Saati Uygulama Saati Laboratuar Hours Kredi AKTS
Veri Yapıları CMPE226 4. Dönem 3 0 0 3 8
Ön Koşul Ders(ler)i
CMPE225
Dersin Dili İngilizce
Dersin Türü Zorunlu Bölüm Dersleri
Dersin Seviyesi Lisans
Ders Verilme Şekli Yüz Yüze
Dersin Öğrenme ve Öğretme Teknikleri Anlatım, Tartışma, Soru Yanıt, Uygulama-Alıştırma, Beyin Fırtınası.
Dersin Koordinatörü
Dersin Öğretmen(ler)i
Dersin Asistan(lar)ı
Dersin Amacı Bu ders problem çözmede kullanışlı olan soyut kavramları tanıtarak bu kavramların programlamada nasıl kullanıldığını anlatır. Öğrenciler özel bir problem için hangi vari yapısının seçilmesi gerektiğini öğrenir, ve karmaşık veri yapılarını yaratmayı öğrenirler.
Dersin Eğitim Çıktıları Bu dersi başarıyla tamamlayabilen öğrenciler;
  • Verilen probleme uygun veri yapısını kullanmak
  • Bağlı listeler, yığıtlar, sıralar, ikili ağaçları kullanmak
  • Özyinelemeyi uygulamak
  • Arama, sıralama ve hesaba dayalı adresleme konularını uygulamak
  • Verilen probleme uygun veri yapısını seçmek
  • Mevcut veri yapılarını kullanarak karmaşık veri tipleri yaratmak
Dersin İçeriği Yığıtlar, özyineleme, yığıtlar, sıralar, dinamik değişkenlerin yaratılması ve yıkılması, bağlı listeler, dairesel listeler, çift bağlı listeler, arama, sıralama ve hesaba dayalı adresleme.

Haftalık Konular ve İlgili Ön Hazırlık Çalışmaları

Hafta Konular Ön Hazırlık
1 Temeller, standard şablon kütüphanesi -STL Bölüm 2, 4 (ders kitabı)
2 Bağlı listeler Bölüm 5
3 Bağlı listeler Bölüm 5
4 Bağlı listeler Bölüm 5
5 Özyineleme Bölüm 6
6 Yığıtlar Bölüm 7
7 Yığıtlar Bölüm 7
8 Sıralar Bölüm 8
9 Sıralar Bölüm 8
10 Arama, Sıralama Bölüm 9, 10
11 Hesaba dayalı adresleme Bölüm 5
12 İkili ağaç yapısı Bölüm 11
13 İkili ağaç yapısı Bölüm 11
14 Yığın Sıralama Bölüm 11
15 Gözden geçirme
16 Gözden geçirme

Kaynaklar

Ders Kitabı 1. Data Structures Using C++, D.S. Malik, Thomson Course Technology, 1st Edition.
Diğer Kaynaklar 2. Data Structures Using C and C++, Y.Langsam, Prentice-Hall International Inc., 2nd Edition.
3. Data Structures and Algorithm Analysis in C++, M. Weiss, Addison Wesley, 3rd Edition
4. Practical Data Structures in C++, B. Flamig, John Wiley & Sons, Pap/Dis Edition.
5. Fundamentals of Data Structures in C++, E. Horowitz, S. Sahni, D. Mehta, Silicon Press, 2nd Edition.
6. Data Structures and Algorithms in C++, M.T. Goodrich, R.Tamassia, D. M. Mount, Wiley, 2nd Edition.

Değerlendirme System

Çalışmalar Sayı Katkı Payı
Devam/Katılım - -
Laboratuar - -
Uygulama - -
Alan Çalışması - -
Derse Özgü Staj - -
Küçük Sınavlar/Stüdyo Kritiği - -
Ödevler - -
Sunum - -
Projeler - -
Rapor - -
Seminer - -
Ara Sınavlar/Ara Juri 2 60
Genel Sınav/Final Juri 1 40
Toplam 3 100
Yarıyıl İçi Çalışmalarının Başarı Notu Katkısı 60
Yarıyıl Sonu Çalışmalarının Başarı Notuna Katkısı 40
Toplam 100

Kurs Kategorisi

Temel Meslek Dersleri
Uzmanlık/Alan Dersleri
Destek Dersleri X
İletişim ve Yönetim Becerileri Dersleri
Aktarılabilir Beceri Dersleri

Dersin Öğrenim Çıktılarının Program Yeterlilikleri ile İlişkisi

# Program Yeterlilikleri / Çıktıları Katkı Düzeyi
1 2 3 4 5
1 Matematik, fen bilimleri ve hesaplama alanlarında yeterli bilgi birikimi kazanır; bu alanlardaki kuramsal ve uygulamalı bilgileri, bilişim sistemleriyle ilgili mühendislik problemlerinin çözümünde kullanabilir. X
2 Karmaşık mühendislik problemlerini saptar, tanımlar, formüle eder ve çözer; bu amaçla uygun analiz ve modelleme yöntemlerini seçer ve uygular. X
3 Karmaşık bir sistemi, süreci, cihazı veya ürünü gerçekçi kısıtlar ve koşullar altında, belirli gereksinimleri karşılayacak şekilde tasarlar; bu amaçla modern tasarım yöntemlerini uygular. X
4 Bilişim sistemleri mühendisliği uygulamalarında karşılaşılan karmaşık problemlerin analizi ve çözümü için gerekli olan modern teknik ve araçları geliştirir, seçer ve kullanır; bilişim teknolojilerini etkin bir şekilde kullanır. X
5 Karmaşık mühendislik problemlerinin veya bilişim sistemleri mühendisliği disiplinine özgü araştırma konularının incelenmesi için, deney tasarlar, deney yapar, veri toplar, sonuçları analiz eder ve yorumlar.
6 Disiplin içi ve çok disiplinli takımlarda etkin biçimde görev yapabilir; bireysel olarak çalışabilir.
7 a. Sözlü ve yazılı etkin iletişim kurar; etkin rapor yazar ve yazılı raporları anlar, tasarım ve üretim raporları hazırlayabilir, etkin sunum yapabilir, açık ve anlaşılır talimat verir ve alır. b. En az bir yabancı dil bilir.
8 Yaşam boyu öğrenmenin gerekliliği konusunda farkındalık kazanır; bilgiye erişebilir, bilim ve teknolojideki gelişmeleri izler ve kendini sürekli yeniler.
9 a. Etik ilkelerine uygun davranır, mesleki ve etik sorumluluk bilinci kazanır. b. Bilişim sistemleri mühendisliği uygulamalarında kullanılan standartlar hakkında bilgi edinir.
10 a. Proje yönetimi, risk yönetimi ve değişiklik yönetimi gibi, iş hayatındaki uygulamalar hakkında bilgi edinir. b. Girişimcilik, yenilikçilik hakkında farkındalık kazanır. c. Sürdürülebilir kalkınma hakkında bilgi edinir.
11 a. Bilişim sistemleri mühendisliği 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ı hakkında bilgi edinir. b. Mühendislik çözümlerinin hukuksal sonuçları konusunda farkındalık kazanır.

ECTS/İş Yükü Tablosu

Aktiviteler Sayı Süresi (Saat) Toplam İş Yükü
Ders saati (Sınav haftası dahildir: 16 x toplam ders saati) 16 3 48
Laboratuar
Uygulama
Derse Özgü Staj
Alan Çalışması
Sınıf Dışı Ders Çalışma Süresi 16 4 64
Sunum/Seminer Hazırlama
Projeler
Raporlar
Ödevler 3 12 36
Küçük Sınavlar/Stüdyo Kritiği
Ara Sınavlara/Ara Juriye Hazırlanma Süresi 2 15 30
Genel Sınava/Genel Juriye Hazırlanma Süresi 1 20 20
Toplam İş Yükü 198