MATEMATİK | |||||
Lisans | TYYÇ: 6. Düzey | QF-EHEA: 1. Düzey | EQF-LLL: 6. Düzey |
Ders Kodu | Ders Adı | Yarıyıl | Teorik | Pratik | Kredi | AKTS |
SEN2211 | Veri Yapıları ve Algoritmalar I | Güz | 2 | 2 | 3 | 7 |
Bu katalog bilgi amaçlıdır, dersin açılma durumu, ilgili bölüm tarafından yarıyıl başında belirlenir. |
Öğretim Dili: | İngilizce |
Dersin Türü: | Non-Departmental Elective |
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 Arş.Gör. MERVE ARITÜRK Prof. Dr. NAFİZ ARICA Öğ.Gör. DUYGU ÇAKIR YENİDOĞAN Arş.Gör. SEVGİ CANPOLAT |
Opsiyonel Program Bileşenleri: | Yok |
Dersin Amacı: | Bu ders yazılım mühendisliğinde kullanılan temel veri yapılarına giriş niteliğindedir. Dersin bitiminde öğrenci, bağlı listeler, yığıtlar ve kuyruklar gibi temel veri yapılarının uygulaması, gerçekleştirilmesi ve analizi hakkında bilgi sahibi olacaktır. Sıralama, arama ve özyineleme gibi temel teknikleri de öğretilecektir. |
Bu dersi başarıyla tamamlayabilen öğrenciler; 1) Temel nesne yönelimli programlama ilkelerini açıklayabilir ve uygulayabilir. 2) Bağlı listeler, yığıtlar ve kuyruklar gibi temel veri yapılarını gerçekleştirebilir. 3) Algoritmaların karmaşıklığını ve performanslarını ölçebilir. 4) Performanslı programlar geliştirebilmek için uygun veri yapılarını seçebilir ve geliştirebilir. 5) Özyinelemeli algoritmalar geliştirebilir. 6) Temel veri yapılarında sıralama işlemini gerçekleştirebilir. 7) Temel veri yapılarında arama işlemini gerçekleştirebilir. |
Dersin içeriği nesne tabanlı Java'ya genel bakış, algoritmaların karmaşıklığı ve verimi, liste-yığın-kuyruk yapılarına giriş, liste-yığın-kuyruk yapılarının uygulamaları, özyineleme, arama algoritmaları ve sıralama algoritmaları konularından oluşmaktadır. |
Hafta | Konu | Ön Hazırlık |
1) | Veri Yapıları ve Algoritmalara Giriş Karmaşıklık Analizi | |
2) | Bağlı Listelere Giriş | |
3) | Çift Bağlı Listeler Sıralı Bağlı Listeler | |
4) | Sıralı Bağlı Listeler Dairesel Bağlı Listeler | |
5) | Yığıtlar | |
6) | Cebirsel İşlemler için Yığıtlar | |
7) | Kuyruklar | |
8) | Kuyruklar | |
9) | Java Veri Yapıları Sınıfları | |
10) | Özyineleme | |
11) | Özyineleme Karmaşıklığı | |
12) | Arama Algoritmaları | |
13) | Sıralama Algoritmaları | |
14) | Sıralama algoritmaları |
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 |
Yarıyıl İçi Çalışmaları | Aktivite Sayısı | Katkı Payı |
Laboratuar | 4 | % 20 |
Küçük Sınavlar | 5 | % 20 |
Ara Sınavlar | 1 | % 20 |
Final | 1 | % 40 |
Toplam | % 100 | |
YARIYIL İÇİ ÇALIŞMALARININ BAŞARI NOTU KATKISI | % 60 | |
YARIYIL SONU ÇALIŞMALARININ BAŞARI NOTUNA KATKISI | % 40 | |
Toplam | % 100 |
Aktiviteler | Aktivite Sayısı | İş Yükü |
Ders Saati | 14 | 28 |
Laboratuvar | 14 | 28 |
Sınıf Dışı Ders Çalışması | 12 | 24 |
Ara Sınavlar | 10 | 52 |
Final | 5 | 32 |
Toplam İş Yükü | 164 |
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) | Temel matematik, uygulamalı matematik teori ve uygulamalarını kavramış olmak | |
2) | Matematiksel ispatları anlamak ve onlara erişebilmek ve uygun ispatları inşa edebilmek ve ayrıca, problemleri tanımlayabilmek, onları analiz edebilmek ve problemlere bilimsel metotlara dayalı çözümler bulmak | |
3) | Matematiği disiplinler arası bir yaklaşım ile gerçek hayata uygulayabilmek ve bunların etkin potansiyelini keşfetmek | |
4) | Kendisini geliştirmek ve matematiğin kullanıldığı alanlarda modelleme yapabilecek seviyede gerekli bilgi birikimini elde etmek | 4 |
5) | Teorik ve teknik bilgileri detaylı bir biçimde uzmanlara, basit ve anlaşılabilir bir biçimde uzman olmayanlara anlatabilmek | |
6) | Matematik alanında kullanılan bilgisayar programlarına aşina olmak ve bunlardan en az birini İleri Düzey Avrupa Bilgisayar Ehliyeti(the European Computer Driving Licence Advanced Level) seviyesinde kullanmak | |
7) | Görev aldığı projelerin her adımında sosyal, bilimsel ve etik değerlere uygun davranmak ve çevre katılımı kapsamında proje tanıtımı ve uygulamaları yapabilmek | |
8) | Evrensel anlamda bir entelektüel birikime sahip olarak tüm süreçleri etkin bir biçimde değerlendirmek ve kalite yönetimi hakkında yeterli farkında lığa sahip olmak | 4 |
9) | Soyut düşünme yeteneğine sahip bir biçimde somut olaylar arasında ilgi kurmak, çözümleri aktarmak, deneyler tasarlamak, veri toplamak ve sonuçları bilimsel metotlarla analiz etmek ve müdahil olmak | |
10) | Yaşam boyu öğrenme hakkında bilinçli olarak, program boyunca edinilen bilgi, beceri ve yeteneklerini yenileyerek yaşam boyu öğrenmenin devamını sağlamak | |
11) | Cebir, analiz, sayılar teorisi, mantık, geometri ve topoloji gibi matematik alanlarında kazandığı bilgiyi ortaöğretim seviyesine uyarlamak ve aktarmak | |
12) | Yalnız veya bir ekibin elemanı olarak araştırma yapmak, bir projenin ilgili her adımında etkili olmak, karar verme süreçlerine katılmak, zamanı etkili kullanarak proje planlamak ve yürütmek |