2025 (Current Year) Faculty Courses School of Computing Undergraduate major in Computer Science
Procedural Programming Fundamentals
- Academic unit or major
- Undergraduate major in Computer Science
- Instructor(s)
- Shio Miyafuji
- Class Format
- Lecture/Exercise (Face-to-face)
- Media-enhanced courses
- -
- Day of week/Period
(Classrooms) - 7-8 Mon / 5-8 Thu
- Class
- -
- Course Code
- CSC.T243
- Number of credits
- 210
- Course offered
- 2025
- Offered quarter
- 1Q
- Syllabus updated
- Apr 2, 2025
- Language
- Japanese
Syllabus
Course overview and goals
This course provides the theory and practice for fundamental procedural C programming, by means of lectures and exercises.
In the first half, students acquire grammar knowledge on C languages such as data types, operators, control structures, functions and recursion through lectures and exercises. In the second half, students learn algorithms to solve concrete problems such as search and sorting. In addition, array, file I/O, character and string types, etc. are acquired along with the knowledge learned in the first half. In the second half exercise, students are requested to fully utilize those knowledge and skills to implement large programs for statistical analysis and searching for large amount of data.
Course description and aims
(1) Understand data types, standard input/output, operators, control flows, functions, recursion, arrays, file input/output and character/string types of C language, and create programs utilized them.
(2) Understand multiple search algorithms and sorting algorithms, and create programs to realize them.
(3) Create programs to solve problems such as data analysis, and explain their solutions.
Keywords
Procedural programming, data type, standard I/O, control flow, array, function, file I/O, recursion, sort, search, algorithm, and data analysis
Competencies
- Specialist skills
- Intercultural skills
- Communication skills
- Critical thinking skills
- Practical and/or problem-solving skills
Class flow
Three time slots in one week consists of a single slot for a lecture and two slots for exercises related to the lecture.
Course schedule/Objectives
Course schedule | Objectives | |
---|---|---|
Class 1 | [Lecture 1] Hardware/software, integer/real type, operator, and standard I/O | Available during each class. |
Class 2 | [Exercise 1] Introduction to fundamental programming and preparation to computer environments | Available during each class. |
Class 3 | [Lecture 2] Control flow (conditional branch, loop) | Available during each class. |
Class 4 | [Exercise 2] Hardware/software, four arithmetic operations, and standard I/O | Available during each class. |
Class 5 | [Lecture 3] Function, recursion, and scope of the variables | Available during each class. |
Class 6 | [Exercise 3] Control flow | Available during each class. |
Class 7 | [Lecture 4] Array, multi-dimensional arrays, and file I/O | Available during each class. |
Class 8 | [Exercise 4] Function and recursion | Available during each class. |
Class 9 | [Lecture 5] character and string type | Available during each class. |
Class 10 | [Exercise 5] Array, multi-dimensional arrays, and file I/O | Available during each class. |
Class 11 | [Lecture 6] Search algorithm | Available during each class. |
Class 12 | [Exercise 6] Program design related to basic information processing task (statistics, measurement, and control, etc.), research ethics | Available during each class. |
Class 13 | [Lecture 7] Sort algorithm | Available during each class. |
Class 14 | [Exercise 7] Program implementation of basic information processing task. | Available during each class. |
Study advice (preparation and review)
To enhance effective learning, students are encouraged to spend a certain length of time outside of class on preparation and review (including for assignments), as specified by the Tokyo Institute of Technology Rules on Undergraduate Learning (東京工業大学学修規程) and the Tokyo Institute of Technology Rules on Graduate Learning (東京工業大学大学院学修規程), for each class.
They should do so by referring to textbooks and other course material.
Textbook(s)
Materials will be available during each lecture and exercise.
Reference books, course materials, etc.
Brian W. Kernighan, Dennis M. Ritchie. C Programming Language (Second Ed.), Prentice Hall, 1988.
Evaluation methods and criteria
In-class assignments/exams (50%) and reports for project-based programming (50%)
Related courses
- CSC.T253 : Advanced Procedural Programming
- CSC.T263 : Functional Programming Fundamentals
- CSC.T273 : Object-Oriented Programming
- CSC.T271 : Data Structures and Algorithms
- CSC.T344 : System Programming
- CSC.T354 : Parallel Programming
- CSC.T362 : Numerical Analysis
- LAS.I111 : Information Literacy I
- LAS.I112 : Information Literacy II
Prerequisites
This unit is recommended for 2nd-year students from the CS department. Due to the limited space and the number of equipment, this unit may not be able to accept students from other departments. Registered students MUST attend the first lesson.
Office hours
Wednesday afternoon (appointment via email is required)