FI:PB161 C++ Programming - Course Information
PB161 C++ Programming
Faculty of InformaticsAutumn 2013
- Extent and Intensity
- 2/2. 4 credit(s) (plus extra credits for completion). Recommended Type of Completion: zk (examination). Other types of completion: z (credit).
- Teacher(s)
- doc. RNDr. Petr Švenda, Ph.D. (lecturer)
Mgr. Ondřej Bouda (seminar tutor)
Mgr. Tomáš Brukner (seminar tutor)
RNDr. Jiří Glozar (seminar tutor)
Mgr. Jan Juráň (seminar tutor)
Bc. Dalibor Matura (seminar tutor)
Mgr. Michal Mikloš (seminar tutor)
RNDr. Lukáš Ručka (seminar tutor)
RNDr. Marek Vinkler, Ph.D. (seminar tutor)
Mgr. Jiří Weiser (seminar tutor)
Mgr. Ján Bella (assistant)
Bc. Jan Bilík (assistant)
Bc. Čestmír Kalina (assistant)
RNDr. David Klaška (assistant)
Mgr. Lenka Kuníková (assistant)
Mgr. Marek Osvald (assistant)
Mgr. Milan Pánik (assistant)
Mgr. Lubomír Sedlář (assistant)
Mgr. Ing. Tomáš Svoboda (assistant) - Guaranteed by
- doc. RNDr. Vlastislav Dohnal, Ph.D.
Department of Computer Systems and Communications – Faculty of Informatics
Supplier department: Department of Computer Systems and Communications – Faculty of Informatics - Timetable
- Mon 14:00–15:50 D3
- Timetable of Seminar Groups:
PB161/01: Wed 14:00–15:50 C525, M. Vinkler
PB161/02: Fri 8:00–9:50 B130, M. Mikloš
PB161/03: Thu 14:00–15:50 B130, J. Juráň
PB161/04: Fri 12:00–13:50 B130, D. Matura
PB161/05: Wed 12:00–13:50 B116, M. Vinkler
PB161/06: Wed 8:00–9:50 B117, L. Ručka
PB161/07: Thu 16:00–17:50 B116, J. Juráň
PB161/08: Mon 18:00–19:50 B116, J. Juráň
PB161/09: Mon 18:00–19:50 B117, T. Brukner
PB161/10: Fri 10:00–11:50 B117, D. Matura
PB161/11: Wed 18:00–19:50 B117, L. Ručka
PB161/12: Tue 8:00–9:50 B116, J. Weiser
PB161/13: Thu 12:00–13:50 B117, O. Bouda
PB161/14: Thu 10:00–11:50 C525, O. Bouda
PB161/15: Thu 18:00–19:50 B116, M. Mikloš
PB161/16: Thu 8:00–9:50 B117, J. Weiser
PB161/17: Tue 14:00–15:50 B117, P. Švenda - Prerequisites
- PB071 Introduction to the C language || SOUHLAS
Students are also required to have user experience with Unix OS, as homework is submitted and tested on a Unix server. - Course Enrolment Limitations
- The course is also offered to the students of the fields other than those the course is directly associated with.
- fields of study / plans the course is directly associated with
- Applied Informatics (programme FI, B-AP)
- Bioinformatics (programme FI, B-AP)
- Economic Information Systems (programme ESF, B-SI)
- Informatics with another discipline (programme FI, B-BI)
- Informatics with another discipline (programme FI, B-EB)
- Informatics with another discipline (programme FI, B-FY)
- Informatics with another discipline (programme FI, B-GE)
- Informatics with another discipline (programme FI, B-GK)
- Informatics with another discipline (programme FI, B-CH)
- Informatics with another discipline (programme FI, B-IO)
- Informatics with another discipline (programme FI, B-MA)
- Informatics with another discipline (programme FI, B-TV)
- Public Administration Informatics (programme FI, B-AP)
- Mathematical Informatics (programme FI, B-IN)
- Mathematics for Multi-Branches Study (programme PřF, B-MA)
- Mathematics with Informatics (programme PřF, N-MA)
- Mathematics (programme PřF, B-MA)
- Parallel and Distributed Systems (programme FI, B-IN)
- Computer Graphics and Image Processing (programme FI, B-IN)
- Computer Networks and Communication (programme FI, B-IN)
- Computer Systems and Data Processing (programme FI, B-IN)
- Profesional Mathematics (programme PřF, B-MA)
- Programmable Technical Structures (programme FI, B-IN)
- Embedded Systems (programme FI, N-IN)
- Service Science, Management and Engineering (programme FI, N-AP)
- Social Informatics (programme FI, B-AP)
- Artificial Intelligence and Natural Language Processing (programme FI, B-IN)
- Course objectives
- At the end of the course students should be able to:
Understand to principles of object oriented programming.
Design simple object oriented architectures and implement them.
Understand and use basic C++ syntax according to ANSI norm.
Use common C++ libraries, especially STL.
Annotate source code with respect to automatically generated documentation.
Use modern development tools (IDE, debugger, version control...).
Follow best practices guidelines for C++ programming.
Compile programs both under Unix and Windows. - Syllabus
- Basic features of C++ (with respect to C). Standards, compilers.
- Basic principles of object oriented programming (OOP). Object programming methodologies.
- User defined data types. Classes in C++. Class components.
- OOP in C++. Encapsulation, Inheritance, Polymorphism.
- Dynamic memory allocation. Dynamic memory management. Automatic and class pointers.
- Input and output in C++.
- Exception handling. Defensive programming.
- Templates. Standard C++ library and standard template library. Libraries for numeric computing.
- Application of object oriented design and design patterns in C++.
- Other OOP languages. Java and C# as compared to C++.
- Literature
- STROUSTRUP, Bjarne. The C++ programming language. 3rd ed. Reading: Addison-Wesley, 1997, x, 910 s. ISBN 0-201-88954-4. info
- VIRIUS, Miroslav. Programování v C++. 1. vyd. Praha: ČVUT, 1998, 364 s. ISBN 8001018741. info
- VIRIUS, Miroslav. Pasti a propasti jazyka C++ : podrobný průvodce pokročilého uživatele. 1. vyd. Praha: Grada, 1997, 251 s. ISBN 8071696072. info
- VIRIUS, Miroslav. Od C k C++. 1. vyd. České Budějovice: KOPP, 2000, 227 s. ISBN 80-7232-110-2. info
- LOUIS, Dirk, Petr MEJZLÍK and Miroslav VIRIUS. Jazyky C a C++ podle normy ANSI/ISO: kompletní kapesní průvodce. 1. vyd. Praha: Grada Publishing, 1999, 644 s. ISBN 80-7169-631-5. info
- MEYERS, Scott. Effective C++ :50 specific ways to improve your programs and designs. 2nd ed. Reading: Addison-Wesley, 1998, xx, 256 s. ISBN 0-201-92488-9. info
- Bookmarks
- https://is.muni.cz/ln/tag/FI:PB161!
- Teaching methods
- Teaching consists from theoretical lectures combined with the practical exercises and programming homework selected to practice topics from lectures.
- Assessment methods
- During the whole semester, student will undertake 5 programming homework, two written tests and one final programming exercise. 50 % of points are required to pass the course in addition to successful competition of final programming exercise.
In seminars, the students create programs requested (usually finishing it as individual work). The programs are rated in a point scale using previously given criteria. Preferably the course is ended by an examination made by a computer testing program. To be allowed to pass the test, the student must obtain the credit from the seminar and produce a final program. The classification depends on the quality of work in the seminar, quality of the final program and the result of the test.
If the student chose finishing the course with a seminar credit only, he has to finish the programs given throughout the term. No final program nor the test is required in that case. - Language of instruction
- Czech
- Further comments (probably available only in Czech)
- Study Materials
The course is taught annually. - Listed among pre-requisites of other courses
- IB113 Introduction to Programming and Algorithms
!NOW(IB111) && !IB111 && !PB162 && !PB161 && !PB071 && !IB001 && !program(B-INF) && !program(B-PVA) && !program(B-CS) - PB007 Software Engineering I
PB160 || PB161 || PB162 || PB174 || PV178 || PB112 - PV255 Game Development I
PB009 && PV112 && (PB161 || PB162 || PV178) - PV294 Advanced C++
PB161
- IB113 Introduction to Programming and Algorithms
- Teacher's information
- http://cecko.eu/public/pb161
- Enrolment Statistics (Autumn 2013, recent)
- Permalink: https://is.muni.cz/course/fi/autumn2013/PB161