Informática para Ciências e Engenharias B

Objetivos

Saber

Os componentes fundamentais de um computador.

As ferramentas de um ambiente de desenvolvimento de software.

As construções essenciais de uma linguagem de programação imperativa.

Algumas noções fundamentais de bases de dados relacionais.

Alguns conceitos básicos relacionados com a World Wide Web.

Saber Fazer

Decompor um problema em problemas mais simples.

Conceber um algoritmo para resolver um problema simples.

Escrever um programa, utilizando correctamente as construções básicas de uma linguagem de programação imperativa.

Testar um programa num determinado ambiente de programação.

Formular uma interrogação muito simples em SQL.

Aceder a recursos disponíveis na rede dentro de um programa.

Soft-Skills

Capacidade de concretização.

Capacidade de gestão do tempo e cumprimento dos prazos.

Caracterização geral

Código

11146

Créditos

6.0

Professor responsável

Teresa Isabel Lopes Romão, Vítor Manuel Alves Duarte

Horas

Semanais - 4

Totais - 59

Idioma de ensino

Português

Pré-requisitos

Esta disciplina não tem pré-requisitos.

Bibliografia

Allen B. Downey. Think Python: How to Think Like a Computer Scientist. PDF e HTML em http://greenteapress.com/wp/think-python-2e/

Charles Severance. Python for Everybody: Exploring Data Using Python 3. PDF e HTML em https://www.py4e.com/book.php. Esta é uma versão baseada na referência anterior contendo novos capítulos sobre Internet e bases de dados. Inclui também uma versão (trinket.io) onde os exemplos podem ser alterados e executados dentro do livro. 

Sebenta do Prof. Ludwig Kripahl     (http://iceb.ssdi.di.fct.unl.pt/1920/files/ICEB_notes.pdf)

Método de ensino

Há duas horas de aulas teóricas e duas horas de aulas práticas por semana.

As aulas teóricas são orientadas para a resolução de problemas. Começa-se com o enunciado de um problema muito concreto, que motiva a apresentação de um tópico dos sistemas de computadores, de um tipo de dados ou de uma construção da linguagem de programação, e termina-se com o código IGNOREe completo de um programa que o resolve.

Nas aulas práticas, os alunos concebem, implementam e testam programas que resolvem problemas simples das áreas das Ciências e Engenharias.

Método de avaliação

Regras de Avaliação

Componentes da Avaliação

A avaliação é constituída por duas componentes: a componente laboratorial e a componente teórico-prática.

*****   Componente Laboratorial e Frequência   *****

A componente laboratorial é composta por 3 exercícios e 1 trabalho prático, realizados em grupo de dois alunos (ou individualmente, em casos justificados), sendo o trabalho realizado maioritariamente fora das aulas.

A avaliação dos trabalhos é feita individualmente, durante os correspondentes testes, que incluirão um grupo de perguntas relacionadas com os respetivos trabalhos. A avaliação desses grupos é condicionante da nota final atribuída aos trabalhos, mas não da nota dos testes.

A nota da componente laboratorial (CompL) é obtida da seguinte forma:

 • compL = 0,2 Q1 + 0,2 Q2 + 0,6 TP  (onde Q1 e Q2 são os dois melhores resultados dos 3 exercícios).

Para obter frequência, é necessário que CompL ≥ 8.0.



*****   Componente Teórico-Prática   *****

A componente teórico-prática é composta por dois testes (no período de aulas) ou por um exame (na Época de Recurso). As três provas são individuais, escritas e sem consulta. Os alunos não poderão consultar qualquer material, nem utilizar qualquer dispositivo eletrónico. 

A nota da componente teórico-prática (CompTP) é a média aritmética das notas dos testes (T1 e T2) ou a nota do exame (Ex).

Para obter aprovação, é necessário que CompTP ≥ 8.0.

*****   Nota Final   *****
A nota final (NF) dos alunos com frequência é calculada da seguinte forma:
    • NF = CompTP,                        se CompTP < 8,0;
    • NF = 0,3 CompL + 0,7 CompTP,        se CompTP ≥ 8,0 .

Todas as notas são arredondadas às décimas, numa escala de 0 a 20 valores, excepto a nota final (NF) que é arredondada às unidades.

*****    Classificações Obtidas em Anos Anteriores   *****
Os alunos que obtiveram frequência na UC desde o ano 2018/19 (em que foi usada a linguagem Python) podem manter essa nota CompL.
Se quiserem manter a frequência anterior, não deverão inscrever-se nas aulas práticas e essa nota corresponde à CompL acima. Se se inscreverem nas aulas práticas, a nota CompL será a nota obtida este ano.

Conteúdo

Introdução: Problemas, algoritmos, programas e computadores. Objectivos e componentes de um sistema computacional. Execução de programas. O interpretador.

Conceitos Fundamentais da Programação: Constantes, variáveis e expressões. Números e strings. Funções pré-definidas. Atribuição e sequência de instruções. Níveis de abstracção na resolução de um problema. Funções. Ficheiros com código IGNOREe. Ciclo de vida de um programa. Tipos de erros. Testes unitários. Ciclos FOR. Vectores. Instrução IF. Operadores relacionais e lógicos. Matrizes. Gráficos. Ciclos WHILE. Sistema de ficheiros. Ficheiros em binário e em ASCII. Estruturas. Vectores de estruturas.

Redes e protocolos de comunicação. A WWW.

Introdução às bases de dados: modelo relacional, relações, algumas instruções básicas de SQL.

Simulação de modelos contínuos.

Cursos

Cursos onde a unidade curricular é leccionada: