YAPAY ZEKA MÜHENDİSLİĞİ | |||||
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 | Bahar | 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) | Matematik, fen bilimleri ve yapay zeka mühendisliği konularında yeterli altyapıya sahiptir. | |
2) | Matematik, fen bilimleri ve yapay zeka mühendisliği alanlardaki kuramsal ve uygulamalı bilgileri mühendislik çözümleri için beraber kullanır. | |
3) | Mühendislik problemlerini saptar, tanımlar, formüle eder ve çözer, bu amaçla uygun analitik yöntemler ve modelleme tekniklerini seçer ve uygular. | |
4) | Bir sistemi, sistem bileşenini ya da süreci analiz eder ve istenen gereksinimleri karşılamak üzere gerçekçi kısıtlar altında tasarlar; bu doğrultuda modern tasarım yöntemlerini uygular. | |
5) | Mühendislik uygulamaları için gerekli olan modern teknik ve araçları seçer ve kullanır. | |
6) | Deney tasarlar, deney yapar, veri toplar sonuçları analiz eder ve yorumlar. | |
7) | Bireysel olarak ve çok disiplinli takımlarda etkin olarak çalışır. | |
8) | Bilgiye erişir ve bu amaçla kaynak araştırması yapar, veri tabanları ve diğer bilgi kaynaklarını kullanır. | |
9) | Yaşam boyu öğrenmenin gerekliliği bilincindedir; bilim ve teknolojideki gelişmeleri izler ve kendini sürekli yeniler. | |
10) | Alanının gerektirdiği en az Avrupa Bilgisayar Kullanma Lisansı İleri Düzeyinde bilgisayar yazılımı ile birlikte bilişim ve iletişim teknolojilerini kullanır. | |
11) | Sözlü ve yazılı etkin iletişim kurar; bir yabancı dili en az Avrupa Dil Portföyü B1 Genel Düzeyinde kullanır. | |
12) | Mühendislik çözümlerinin ve uygulamalarının evrensel ve toplumsal boyutlardaki etkilerinin bilincinde olur; girişimcilik ve yenilikçilik konularının farkında olur ve çağın sorunları hakkında bilgiye sahiptir. | |
13) | Mesleki ve etik sorumluluk bilincine sahiptir. | |
14) | Proje yönetimi, işyeri uygulamaları, çalışanların sağlığı, çevre ve iş güvenliği konularında bilinç; mühendislik uygulamalarının hukuksal sonuçları hakkında farkındalığa sahiptir. |