Categories
Algorithms and Programming I

Lecture Notes

HaftaKonuİndirme
1Giriş
2Akış Diyagramları
3C’e Genel Bakış, Değişkenler ve Operatörler
4Resmi Tatil
5Seçim ve Kontrol Yapıları
6Fonksiyonlar
7Vize
8Test ve Hata Ayıklama
9İşaretçiler
10Diziler
11Özyinelemeli Fonksiyonlar
12Karakterler, Girdi/Çıktı Formatlama, Dosya Okuma ve Yazma
13C Yapıları
14Önişlemler ve Diğer Konular
15Final ve Proje Sunumları
Categories
Algorithms and Programming I

Syllabus

HaftaKonuTarih
1Giriş8.10.2019
2Akış Diyagramları15.10.2019
3C’e Genel Bakış, Değişkenler ve Operatörler22.10.2019
4Resmi Tatil29.10.2019
5Seçim ve Kontrol Yapıları5.11.2019
6Fonksiyonlar12.11.2019
7Vize19.11.2019
8Test ve Hata Ayıklama26.11.2019
9İşaretçiler3.12.2019
10Diziler10.12.2019
11Özyinelemeli Fonksiyonlar17.12.2019
12Karakterler, Girdi/Çıktı Formatlama, Dosya Okuma ve Yazma24.12.2019
13C Yapıları31.12.2019
14Önişlemler ve Diğer Konular7.1.2020
15Final ve Proje SunumlarıSınav Haftası
  
Categories
Algorithms and Programming I

Detailed Course Description

Ders Açıklaması

Bu dersin amacı algoritma tasarımı, analizi ve optimizasyonu yapabilme becerisi kazandırmaktır. Ders kapsamında problem çözme, C dili ile çeşitli algoritma geliştirme yöntemleri aktarılmaktadır. Kontrol yapıları, döngüler, fonksiyonlar, diziler, işaretçiler kullanılarak bilgisayar programlarının tasarımları öğretilmektedir. Dosya işleme, yapılar ve kullanım alanları, yeniden kullanılabilir kod kavramı ve verimli kod geliştirme kavramları hakkında bilgi verilmektedir.

Ders Saatleri (Teorik + Lab)

Salı 09.00-13.00

Öğretim Elemanları ve Ofis Saatleri

Dr. Öğr. Üyesi Vecdi Emre Levent, Ofis 311 – Pazartesi 17.00-18.00, Salı 16.00-17.00

Arş. Gör. Uğur Özbalkan, Ofis 311 –  Salı 16.00-17.00, Cuma 16.00-17.00

Ön Gereksinimler

Yok

Yardımcı Kaynaklar

Dersin referans kaynakları aşağıda listelenmektedir.

  • Kernighan & Ritchie, The C Programming Language, Prentice Hall
  • Deitel & Deitel, C How to Program, Prentice Hall
  • Problem Solving & Programming Design In C, Fourth Edition, Jeri R. Hanly and Elliot B. Koffman
  • Introduction to Algorithms, Third Edition, T.H. Cormen, C.E. Leiserson, R.L. Rivest and C. Stein, MIT Press

Yazılımlar

C dili ile geliştirilecek olan uygulamalar, Visual Studio Community kullanılarak derlenecektir.

Dersler

Dersin haftalık 2 saat teorik, 2 saat laboratuvar bölümü bulunmaktadır. Öğretim üyesi tarafından verilen ders materyallerinin ders öncesi incelenip, ders sonrasında ise tekrar edilmesi beklenmektedir. 

Öğrenim Çıktıları

  • Bir problemin birden çok çözüm yöntemini kıyasyabilme
  • Basit veri yapılarıyla algoritma kurma becerisi
  • Yeniden kullanılabilir ve optimize kod tasarımı
  • Özyinelemeli fonksiyonlar ile tasarım
  • C dili ile algoritma geliştirme kabiliyeti

Quizler

Dönem içerisinde iki adet quiz yapılacaktır. 30 dk süre verilecektir. Quiz tarihi bir hafta önceden duyurulacaktır. 

Notlandırma

Derslere %80 oranında devam zorunludur.

Dönem notu; vize, lablar, ödevler, proje ve final sınavı ile belirlenecektir. Değerlendirme yüzdeleri aşağıdaki tabloda verilmiştir.

FaaliyetlerOranlar
Vize%15
Ödev/Quiz%10
Lab%15
Proje%40
Final%20
Bonus5 Puan’a kadar

Ödev ve quizlerin teslim saati üzerinden her geçen saat için 5 puan kesilecektir.

Dönem sonu notunun karşılık geldiği ağırlık ve harf notu aşağıdaki tabloda verilmiştir.

Dönem NotuAğırlıkHarf Notu
90-1004.00AA
85-893.50BA
80-843.00BB
75-792.50CB
65-742.00CC
50-641.50DC
45-491.00DD
0 -440FF

Beklenen Efor

Öğrencinin dönem içinde göstermesi beklenen efor tablosu aşağıda verilmiştir.

İçerikSaatKaç DefaAra Toplam
Derse Hazırlık21428
Ders Tekrarı21428
Ödev4624
Proje48148
Sınıf Dersi41456
Ara Sınav ve Final326


Öğrenciler dersten başarılı olmak için dönem boyunca ortalama 190 saat harcamaları beklenmektedir.

Kodlama Ödevleri

Kodlama ödevlerinin notlandırılması, kodun doğruluğu, kalite ve algoritmik gerçeklemedeki detayları incelenerek yapılacaktır.

Doğruluk

Verilecek her bir ödev için test girişi ve beklenen çıkışlar paylaşılacaktır. Ancak ödev kontrolü yapılırken sizinle paylaşılmamış başka test durumları da denenecektir. Çalışma zamanı, beklenenden çok uzun süren kodlar yanlış olarak değerlendirilebilir.

Teori

Kod, istenen algoritmanın tasarımı olmalıdır. En optimum çözüm beklenmemektedir. Ancak bellek ve çalışma zamanı beklenenden çok fazla olmamalıdır.

Yazılı Ödevler

Ödev kendi el yazınız ile yazılmalıdır. Ödev cevap kağıtının üzerinde, dersin adı, öğrenci adı ve soyadı, öğrenci numarası ve tarih bulunmalıdır. 

Akademik Dürüstlük

Ödevin amacı, ders hakkında derinlemesine araştırma yapmayı öğrenmek ve pratik bilgiler kazanmayı sağlamaktır. Verilen ödevler hakkında, diğer öğrenciler ile birlikte çalışma teşvik edilmektedir. Çalışma grubu oluşturan öğrenciler, kendi başına çalışan öğrencilere göre sınavlarda daha başarılı olmaktadırlar. 

Ancak bir ödevi çözmek için başkaları ile birlikte çalışsanız bile, her bir sorunun çözümünü yardım almadan kendiniz yapmalısınız. Çözümünüzü bir araştırma yolu ile elde ederseniz (örn. bir internet araması), çözümü kendi cümle ve/veya kodunuz ile ifade etmelisiniz. Çözümü sözlü olarak sorulduğunda, öğrencinin açıklayabilmesi beklenmektedir. 

Verilen ödev bir kod ise, kendinizin yazması gerekmektedir. Hata ayıklamada başkalarından yardım alabilirsiniz. Kodda intihal tespiti için manuel ve otomatik mekanizmalar kullanılacaktır. İntihal, sınav içi kopya ve benzeri davranışlar disiplin yönetmeliğine göre cezalandırılır.