MATHEMATICS | |||||
Bachelor | TR-NQF-HE: Level 6 | QF-EHEA: First Cycle | EQF-LLL: Level 6 |
Course Code | Course Name | Semester | Theoretical | Practical | Credit | ECTS |
CMP1001 | Introduction to Programming (C++) | Fall | 2 | 2 | 3 | 6 |
This catalog is for information purposes. Course status is determined by the relevant department at the beginning of semester. |
Language of instruction: | English |
Type of course: | Departmental Elective |
Course Level: | Bachelor’s Degree (First Cycle) |
Mode of Delivery: | Face to face |
Course Coordinator : | MEHMET ŞÜKRÜ KURAN |
Course Lecturer(s): |
Dr. Öğr. Üyesi CEMAL OKAN ŞAKAR Dr. UTKU GÜLEN RA ÇİĞDEM ERİŞ Dr. Öğr. Üyesi TARKAN AYDIN Dr. Öğr. Üyesi ERKUT ARICAN Dr. Öğr. Üyesi ÖVGÜ ÖZTÜRK ERGÜN Dr. Öğr. Üyesi ÖZGÜR ERKUT ŞAHİN Dr. Öğr. Üyesi ECE GELAL SOYAK |
Recommended Optional Program Components: | None...... |
Course Objectives: | This course aims to provide an overview of programming concepts, design and an introduction to coding using the C++ language. The course has a focus on creating working computer programs in C++. This course will address fundamental concepts of analysis, design, code development, and testing. |
The students who have succeeded in this course; I. Identifying the components of a computer system II. Defining and analyzing the problem, finding a logical sequence of precise steps, developing algorithms III. Having knowledge of the fundamental programming concepts IV. Developing computer programs with C++ V. Understanding the basics of structured programming VI. Gaining hands-on experience to develop object oriented thinking VII. Becoming familiar with some major data structures and algorithms VIII. Becoming familiar with advanced programming concepts of C++ |
An Introduction to Important Concepts of Computer System (Computer Components, Software, Operating System, File System, Programming Languages, Compilers) Problem Solving (Algorithms, Pseudocode, Flow-chart), Algorithm Design Primitive Data Types, Constants, Variables, Identifiers, Named Constants, Arithmetic Operations Relational and Logical Operators, Conditional Statements ('If' Selection Structures, 'Switch Case' Blocks) Repetition Structures (Do/While Repetition Structure, the for repetition structure), break and continue statements Repetition Structures (Do/While Repetition Structure, the for repetition structure), break and continue statements Functions, Recursion, Function Overloading Strings, String functions Arrays Multi-Dimensional Arrays Sorting, Seaching arrays Pointers Pass By Reference with Pointers, Arrays of Pointers, |
Week | Subject | Related Preparation |
1) | An Introduction to Important Concepts of Computer Systems (Computer Components, Software, Operating System, File System, Programming Languages, Compilers) | Reading about important concepts of computer systems from textbook |
2) | Problem Solving (Algorithms, Pseudocode, Flow-chart), Algorithm Design | Having knowledge about algorithm design techniques from the course book and other sources |
3) | Primitive Data Types, Constants, Variables, Identifiers, Named Constants, Arithmetic Operations | Designing sample programs using the pseudo-code and flowchart algorithm design techniques Reading the sections of the text book about Primitive Data Types, Constants, Variables, Named Constants, Arithmetic Operations |
4) | Quiz, Relational and Logical Operators, Conditional Statements | Writing simple C++ programs |
5) | Do/While Repetition Structures | Developing programs that contains relational and logical operators Reading the related parts of the course book and reference sources with loops |
6) | For repetition structures, break and continue statements | Writing the pseudo-codes, drawing flowcharts and writing C++ codes of sample programs |
7) | Quiz, Functions, Recursion, Inline functions, Function Overloading | Having knowledge about modular programming from course book and reference sources |
8) | Arrays in C++ | Developing sample C++ programs with functions |
9) | Strings, String functions | Reading the related sections of the course book and reference sources with strings and built-in string functions |
11) | Multi-dimensional arrays | Developing sample C++ programs related with arrays |
12) | Quiz, Sorting Arrays, searching in Arrays | Writing sample programs about strings, using built-in string functions in C++ programs |
13) | Pointers | Developing C++ programs that include array sorting and searching algorithms Reading the related topics of course book and reference sources with pointers |
14) | Pass by Reference to Functions with Pointers, Function Pointers | Developing C++ programs about pointers |
Course Notes / Textbooks: | Paul J. Deitel, Harvey M. Deitel, C++ How to Program, 7th Ed., Pearson Bjarne Stroustrup, The C++ Programming Language, 3rd Ed., Addison-Wesley. Bjarne Stroustrup, Programming Principles and Practice Using C++, 1st Ed., Addison-Wesley. Walter Savitch, Problem Solving with C++, 7th Ed., Addison-Wesley Andrei Alexandrescu, Herb Sutter, C++ Design and Coding Standards: Rules and Guidelines for Writing Programs, 1st Ed., Addison-Wesley. |
References: | http://www.cplusplus.com/doc/tutorial/ http://www.cprogramming.com/ |
Semester Requirements | Number of Activities | Level of Contribution |
Quizzes | 4 | % 25 |
Midterms | 1 | % 35 |
Final | 1 | % 40 |
Total | % 100 | |
PERCENTAGE OF SEMESTER WORK | % 60 | |
PERCENTAGE OF FINAL WORK | % 40 | |
Total | % 100 |
Activities | Number of Activities | Workload |
Course Hours | 14 | 28 |
Laboratory | 14 | 28 |
Quizzes | 6 | 12 |
Midterms | 6 | 22 |
Final | 6 | 26 |
Total Workload | 116 |
No Effect | 1 Lowest | 2 Low | 3 Average | 4 High | 5 Highest |
Program Outcomes | Level of Contribution | |
1) | To have a grasp of basic mathematics, applied mathematics and theories and applications in Mathematics | |
2) | To be able to understand and assess mathematical proofs and construct appropriate proofs of their own and also define and analyze problems and to find solutions based on scientific methods, | |
3) | To be able to apply mathematics in real life with interdisciplinary approach and to discover their potentials, | |
4) | To be able to acquire necessary information and to make modeling in any field that mathematics is used and to improve herself/himself, | |
5) | To be able to tell theoretical and technical information easily to both experts in detail and non-experts in basic and comprehensible way, | |
6) | To be familiar with computer programs used in the fields of mathematics and to be able to use at least one of them effectively at the European Computer Driving Licence Advanced Level, | |
7) | To be able to behave in accordance with social, scientific and ethical values in each step of the projects involved and to be able to introduce and apply projects in terms of civic engagement, | |
8) | To be able to evaluate all processes effectively and to have enough awareness about quality management by being conscious and having intellectual background in the universal sense, | |
9) | By having a way of abstract thinking, to be able to connect concrete events and to transfer solutions, to be able to design experiments, collect data, and analyze results by scientific methods and to interfere, | |
10) | To be able to continue lifelong learning by renewing the knowledge, the abilities and the competencies which have been developed during the program, and being conscious about lifelong learning, | |
11) | To be able to adapt and transfer the knowledge gained in the areas of mathematics ; such as algebra, analysis, number theory, mathematical logic, geometry and topology to the level of secondary school, | |
12) | To be able to conduct a research either as an individual or as a team member, and to be effective in each related step of the project, to take role in the decision process, to plan and manage the project by using time effectively. |