28040 - Information Technology (1) (LM)

Academic Year 2022/2023

  • Teaching Mode: Traditional lectures
  • Campus: Bologna
  • Corso: Second cycle degree programme (LM) in Philosophical Sciences (cod. 8773)

    Also valid for First cycle degree programme (L) in Mathematics (cod. 8010)

Learning outcomes

The student will learn a programming language and will be able to design programs using simple algorithms and data structures.

Course contents

Computer science and problem solving. Abstract machines. Python machine. Programming in Python: names and visibility, functions, immutable and mutable objects, basic data types (numbers, strings, tuples, lists, dictionaries) and their use in the solution of problems. Abstract data types: binary trees. Sorting algorithms. Introduction to computational complexity. Limitations of effective procedures: non decidable problems. 


The course involves an important lab activity, where the instructors is joined by teaching assistants.

Readings/Bibliography

John V. Guttag
Introduction to Computation and Programming Using Python
Third Edition: With Application to Computational Modeling and Understanding Data
MIT Press, 2021


Other textbooks:

Allen B. Downey
Think Python 2e.
O'Reilly Media, 2012. ISBN 978-1449330729.
On-line manuscript: see greenteapress.com/wp/think-python-2e/

Jessen Havill
Discovering Computer Science: Interdisciplinary Problems, Principles, and Python Programming
Chapman and Hall/CRC. ISBN 9781482254143

Teaching methods

Lectures.

Guided programming experimentations using the students' PCs, in selected hours, in pair programming if the pandemic will make it possible. 

During the lab hours the instructor is joined by several teaching assistants.

The course is given in the second semester (from mid February to May).

For the students of LM in Scienze Filosofiche: the course is taken from that of L in Mathematics, hence it will be given from mid February to May.

As concerns the teaching methods of this course unit, all students must attend Modules 1 and 2 on Health and Safety online

Assessment methods

There is a single exam covering both the lectures and the lab. Lab homework is assigned every week---this homework is not graded, but if handed in regularly, it will result in one point bonus in the final grade.

Final exam consists of a programming test (0 to 10 points; 5 points needed to pass) and a written test (0 to 24 points; 13 points needed to pass). Final grade is the sum of the two sufficient grades, plus the bonus (if any).

Lab test is waived for the students in Philosophy.

Teaching tools

Info and material available at www.cs.unibo.it/~martini/MATH . During the term of the lectures, material will be available on virtuale.unibo.it

Students are encouraged to install on their PCs Thonny, an environment for the programming language Python 3, which will be used during the lectures.

Office hours

See the website of Simone Martini

SDGs

Quality education

This teaching activity contributes to the achievement of the Sustainable Development Goals of the UN 2030 Agenda.