series lab

32
Instituto Politécnico de Setúbal Escola Superior de Tecnologia Departamento de Sistemas e Informática Aulas de Laboratório Disciplina de Introdução à Programação Ano Lectivo 2004/2005

Upload: portaldoestudantejava

Post on 18-Nov-2014

545 views

Category:

Documents


2 download

DESCRIPTION

 

TRANSCRIPT

Page 1: Series lab

Instituto Politécnico de Setúbal

Escola Superior de Tecnologia

Departamento de Sistemas e Informática

Aulas de Laboratório

Disciplina de Introdução à Programação

Ano Lectivo 2004/2005

Page 2: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série 1: Introdução ao Ambiente de Desenvolvimento

1. Criação de Projectos

Ao longo desta série serão seguidas as instruções do guia “Instalação e utilização do Gel” que indicam o modo de criar um projecto, criar classes, associar ficheiros, compilar, executar,etc. É aconselhavel, para cada um dos exercícios que se seguem, criar uma directoria individual e nela criar o projecto. Assim termos por exemplo: C:\My Documents\Projectos\Exemplo1\ficheiros do projecto Este guia destina-se à prática de utilização do ambiente de desenvolvimento de modo a existir um primeiro contacto com: 1. O sistema de janelas do GEL 2. O sistema de Directorias e Ficheiros 3. Os projectos do GEL 4. O processo de escrita, compilação e execussão de programas 5. A linguagem JAVA

Não é o objectivo deste guia a compreensão total do código Java nos exemplos seguintes

2/32 © DSI

Page 3: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

2. Exemplos

Exemplo 1 Enunciado: Escreva um programa em Java que imprima uma frase. Código: public class Exemplo1 { public static void main(String[] args) { System.out.println("Este é um programa simples"); } }

Exemplo 2 Enunciado: Escreva um programa em Java que peça ao utilizador um número inteiro e o

imprima. Código: public class Exemplo2 { public static void main(String[] args) { System.out.println("Introduza um número inteiro"); int num=Le.umInt(); System.out.println("O número lido é "+num); } }

© DSI 3/32

Page 4: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios Exemplo 3

Enunciado: Escreva um programa em Java que peça ao utilizador dois números inteiros,

os imprima e imprima a sua soma. Código: public class Exemplo3 { public static void main(String[] args) { System.out.println("Introduza 2 números inteiros"); int num1=Le.umInt(); System.out.println("O nº é "+num1); int num2=Le.umInt(); System.out.println("O nº é "+num2); int num3=num1+num2; System.out.println("A soma de "+num1+"+"+num2+" é "+num3); } }

Exemplo 4 Enunciado: Escreva um programa em Java que calcule a area e o perimetro de uma

circunferência a partir do seu raio.. Código: public class Exemplo4 { public static void main(String[] args) { double area, perimetro; double PI=3.1415926; System.out.println("Este programa calcula o perimetro e a area de uma circunferência a partir do seu raio"); System.out.println("Qual o raio da circunferência?"); double raio = Le.umDouble(); area = PI * raio * raio; perimetro = 2 * PI * raio; System.out.println("Raio = "+raio); System.out.println("Area = "+area); System.out.println("Perimetro = "+perimetro); } }

4/32 © DSI

Page 5: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exemplo 5 Enunciado: Escreva um programa em Java que peça ao utilizador um número e diga se

esse número é negativo ou positivo. Código: public class Exemplo5 { public static void main(String[] args) { float a; System.out.println("Introduza um número"); a = Le.umFloat(); if (a<0) { System.out.println("O número "+a+" é negativo"); } else { System.out.println("O número "+a+" é positivo"); } } }

Exemplo 6 Enunciado: Altere o programa anterior de modo a que sejam pedidos números até ser introduzido o valor zero. Código: public class Exemplo6 { public static void main(String[] args) { float a; do { System.out.println("Introduza um número"); a = Le.umFloat(); if (a<0) { System.out.println("O número "+a+" é negativo"); } else if (a>0) { System.out.println("O número "+a+" é positivo"); } else { System.out.println("O número "+a+" não é positivo nem negativo"); } } while (a!=0); }

}

© DSI 5/32

Page 6: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exemplo 7 Enunciado: Escreva um programa em Java que imprima os números inteiros de 4 a 10 inclusive. Código: public class Exemplo7 { public static void main(String[] args) { int i; for (i=4;i<=10;i++) { System.out.println("i é: "+i); } } }

6/32 © DSI

Page 7: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série 2: Tipos Primitivos

Objectivos da Série:

Com esta série de problemas pretende-se que o aluno: 1. Aprenda a escolher o tipo de dados elementar mais apropriado à representação de

quantidades inteiras. 2. Domine a utilização de tipos primitivos de dados

Exercício 1 Mostre como podem os seguintes identificadores ser associados aos respectivos tipos de dados:

indice -> inteiro cmax -> real cmin -> real codigo -> caracter estado -> booleano

Exercício 2 Qual o valor das expressões constantes da tabela 1? Escreva um programa para verificar as soluções por si encontradas.

12*13/5%2+10-5 12/13/5%2+10-5 12%13/5%2+10-5 12+13/5%5+10-5 12-13/5%2+10-5

Tabela 1

Exercício 3 O programa da figura 1 usa o tipo de dado elementar short: class ShortEg { public static void main ( String[] args ) { short value = 32; System.out.println("A short: " + value); } }

Figura 1

Alínea A

Crie um ficheiro denominado ShortEg.java, compile-o e corra-o. Verifique o que o programa escreve no painel de mensagens.

Alínea B

Edite o programa e altere o valor 32 para um outro valor inteiro relativamente baixo, digamos 356. Compile e corra o programa. Em principio tudo deve correr bem.

Alínea C

Altere o valor para 90000 e tente compilar o programa. O que é que acontece? Porquê? Edite o programa e altere a palavra “short” para “int”. Compile e corra o programa. Qual a diferença entre esta e a alínea anterior?

© DSI 7/32

Page 8: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios Exercício 4 O programa da figura 2 usa o tipo de dado elementar double: class DoubleEg { public static void main ( String[] args ) { double value = 32; System.out.println("A double: " + value); } }

Figura 2

Alínea A

Compile e corra o programa. A saída (o que o programa escreve no painel de mensagens) deste programa difere de alguma forma da saída da alínea A do exercício nº3?

Alínea B

Altere o valor da variável B para um valor que seja demasiado grande para uma variável do tipo double. Vai precisar de usar notação científica para o conseguir.

Exercício 5 O programa da figura 3 usa o tipo de dados elementar char: class CharEg { public static void main ( String[] args ) { char ch = 'A' ; System.out.println("A char: " + ch ); } }

Figura 3

Experimente o seguinte: 1) Troque o 'A' por 'Z' compile e corra o programa. 2) Troque o 'A' por 'AA' tente compilar o programa. 3) Troque o 'A' por ' ' compile e corra o programa. Note que existe um espaço entre

as duas plicas. 4) Troque o 'A' por '' tente compilar o programa. Note que não existe nada entre as

duas plicas. 5) Troque o 'A' por "A" tente compilar o programa.

Exercício 6 Para o programa apresentado na figura 4: Public class IncrementaDecrementa { public static void main (String[] args) { Boolean b = false; char c = ‘r’; byte j = 127; short k 32767; Syste.out.println(“c= “ + c); ++c; System.outprintln(“c= “ + c); ++c; System.outprintln(“c= “ + c); Systemout.println(“j= “ + j); --j System.out.println(“j= “ + j); ++j; System.outprintln(“j= “ + j) System.out.println(“k= “ + k); K -=4; System.out.println(“k= “ + k); K +=5;

8/32 © DSI

Page 9: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

System.out.println(“k= “+ k); }

} Figura 4

Alínea A Corrija os erros sintácticos do programa.

Alínea B Escreva o resultado de cada uma das instruções da 6ª à 21ª linha de código.

Exercício 7 Para o programa da figura 5: (note que está escrito a duas colunas) public class ConverteExpandindo { /**Main method*/ public static void main(String[] args) { // Escreve no painel de mensagens { double d = 1.7E308; float f = 3.4E38f; long l = 1234567890123456789L; int i = 1234567890; char c = 'z'; short s = 32767; byte b = 127; double temp; System.out.println(d); System.out.println(f); System.out.println(l); System.out.println(i); System.out.println(c); System.out.println(s); System.out.println(b); temp = d; d = f; System.out.println(d); d = l; System.out.println(d); d = i; System.out.println(d); d = c; System.out.println(d); d = s; System.out.println(d); d = b; System.out.println(d);

Figura 5

Alínea A

Qual a resultado de cada uma das instruções de saída?

Alínea B

Quais as instruções de atribuição que originaram erros?

© DSI

d = temp; temp = f; f = l; System.out.println(f); f = i; System.out.println(f); f = c; System.out.println(f); f = s; System.out.println(f); f = b; System.out.println(f); f = (float) temp; System.out.println(f); temp = i; i = c; System.out.println(i); i = s; System.out.println(i); i = b; System.out.println(i); i = (int) temp; System.out.println(i); temp = c; c = (char) s; System.out.println(c); c = (char) b; System.out.println(c); c = (char) temp; System.out.println(c); } } }

9/32

Page 10: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício 8 Examine o programa da figura 6 class example { public static void main ( String[] args ) { long hoursWorked = 40; double payRate = 10.0, taxRate = 0.10; System.out.println("Hours Worked: " + hoursWorked ); System.out.println("pay Amount : " + (hoursWorked * payRate) ); System.out.println("tax Amount : " + (hoursWorked * payRate * taxRate) ); } }

Figura 6

Alínea a

Modifique-o por forma a que cada variável seja declarada individualmente e não seja inicializada aquando da declaração. Em seguida escreva três instruções de atribuição para associar o valor a cada uma das variáveis. Compile, corra o programa e examine a sua saída.

Alínea B

Agora vamos tentar quebrar o programa. 1) Remova uma das declarações de variáveis. Consegue compilar o programa? 2) Agora remova uma das instruções de atribuição que inicializam uma das variáveis. Quando é que o problema é detectado?

Exercício 9

Considere as declarações de atribuição indicadas abaixo. Mostre o que fica guardado em iresult, fresult e sresult após cada atribuição. Basta verificar até à terceira casa decimal. int iresult,num1=25, num2=40, num3=17, num4=5; int num5=-14, num6=-27; double fresult, val1=17.0, val2=12.78; String sresult, title=”Java Software Solutions”; iresult= num1/num4; fresult=num1/num4; iresult=num3/num4; fresult=num3/num4; fresult=val1/num4; fresult=val1/val2; iresult=num1/num2; fresult=num1/num2; fresult= (double) num1/num2; fresult=num1/(double)num2; fresult= (double) (num1/num2),3); iresult= (int) (val1/num4); fresult= (int) (val1/num4); fresult= (int) ((double)num1/num2); iresult= num3%num4; iresult=num2%num3; iresult=num3%num2; iresult=num2%num4; iresult=num5%num4; iresult=num6%num5; iresult=title.length();fresult=title.length(); iresult=title.indexOf(‘t’); iresult=title.indexOf(‘q’); iresult=title.lastIndexOf(‘a’); sresult=title.toUpperCase(); sresult=title.replace(‘o’,’X’); sresult=title.substring(8); sresult=title.substring(8,16); iresult=(title.substring(8,16)).length(); sresult=title+num1; sresult=title+num1+num2; sresult=title+(num1+num2); iresult=Math.abs(num6); iresult=Math.abs(num1-num2); fresult=Math.sqrt(num2); fresult=Math.pow(num4,3); iresult=Math.max(num2,num3); iresult=Math.floor(val2); iresult=Math.ceil(val2); fresult=Math.sin(num2 + num1*2); fresult=Math.PI*num4; fresult=Math.pow(title.length(),2)+num3*Math.sqrt(num3/num4);

Figura 7

10/32 © DSI

Page 11: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício 10 Indique para as expressões abaixo os resultados. Assuma a seguinte declaração: Random rand= new Random( );

1. rand.nextInt(); 2. Math.abs(rand.nextInt())%20; 3. Math.abs(rand.nextInt()%20); 4. Math.abs(rand.nextInt())% 8 + 1; 5. Math.abs(rand.nextInt())% 45 + 10; 6. Math.abs(rand.nextInt())% 100 - 50; 7. rand.nextInt() % 50; 8. rand.nextFloat(); 9. Math.random(); 10. Math.random()*8; 11. (int)Math.random()*20; 12. (int)Math.random()*20 + 1;

Exercício 11 Para os exercícios seguintes escreva uma expressão usando o Objecto Random para gerar um número aleatório na gama de valores especificada (inclusive).

1. 0 a 10 2. 0 a 500 3. 1 a 10 4. 1 a 500 5. 25 a 50 6. –10 a 15

Exercício 12 Escreva uma expressão usando o método random da classe Math para gerar os números aleatórios na gama de valores especificada.

1. 0 a 10 2. 0 a 500 3. 1 a 10 4. 1 a 500 5. 25 a 50 6. –10 a 15

© DSI 11/32

Page 12: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série 3: Entrada e saída de dados

Objectivos da Série: Com esta série de problemas pretende-se que o aluno:

3. Aprenda a escrever no ecrã informação; 4. Aprenda a ler varios tipos de formatos de dados introduzidos pelo utilizador.

Exercício 1 Considere que está interessado em calcular o valor do polinómio de 2º grau apresentado na figura 5 para diferentes valores de X.

3X2 -8X + 4 Escreva um programa que inclui uma variável de dupla precisão X. Atribua-lhe um valor. Escreva uma instrução que calcule o valor do polinómio e armazene o resultado numa outra variável. Finalmente escreva o resultado sob a forma: para X = 4.0 o resultado é 20.0.

Exercício 2 Escreva um programa que calcule a média de precipitação de três meses, Abril, Maio e junho. Declare e inicialize uma variável com a precipitação de cada mês, calcule a média e escreva o resultado soba a forma: Precipitação em Abril: 12. Precipitação em Maio: 14. Precipitação em Junho 8 Média da precipitação: 11.333333 Para alinhar os valores numéricos use o caracter de tabulação ‘\t’ como parte da string de caracteres nas instruções de saída. Verifique se o programa apresenta os resultados correctos.

Exercício 3 Escreva um programa para resolver cada uma das seguintes situações a) Ler um número inteiro, multiplicá-lo por 2 e escrever o resultado. b) Ler dois números inteiros e escrever a sua soma, diferença e produto. c) Ler dois números reais e escrever a sua soma, diferença e produto.

Exercício 4 Suponha que um café tem a seguinte ementa: prego: 3.5€, Batatas fritas: 1€, Sumo: 0.9€, Bolo: 0,8€, Café: 0,45€. Solicite o numero de doses de cada um dos comestíveis acima indicados e passe uma factura descriminada.

Exercício 5 Escreva um programa para calcular a média de um conjunto de 10 números inseridos pelo utilizador.

Exercício 6 Faça um programa que calcule a taxa de juro de uma conta bancária. Desta forma, terá de pedir ao utilizador que introduza o montante, a taxa de juro e o número de anos. De seguida, deve calcular os juros utilizando a formula:

Montante_final = montante * (taxa_juro / 100) * numero_anos Por fim, deve mostrar no ecrã todos os dados obtidos da seguinte forma: Montante: 5000 € Taxa de Juro: 2,5% Numero de anos: 5 Montante final: 5625 €

12/32 © DSI

Page 13: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício 7 Desenvolva um programa que peça ao utilizador três números inteior, guarde-os em três variaveis (a, b e c) e troque a ordem de forma a que:

1) o valor que estava na variavel a passe a ser o que estava na variavel b;

2) o valor que estava na variavel b passe a ser o que estava na variavel c;

3) o valor que estava na variavel c passe a ser o que estava na variavel a;

Por fim escreva no ecrã o novo valor de cada variavel, com o seguinte formato: a = 10;

b = 4;

c = 1;

Exercício 8 Faça um pequeno programa que mostre no ecrã os seu dados pessoais.

Exercício 9 Altere o programa desenvolvido no exercício anterior de forma a introduzir os seu dados pessoais e só no fim é que mostra todos os seus dados pessoais de uma só vez.

© DSI 13/32

Page 14: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série 4: Instruções de selecção (IF e SWITCH)

Objectivos da Série: Com esta série de problemas pretende-se que o aluno:

1. Aprenda a usar as estruturas de selecção if e switch 2. Domine a utilização das estruturas if e switch nas suas várias formas.

Exercício 1 Este exercício deve utilizar a intrução de selecção if.

Alínea A

Escreva um programa para ordenar dois inteiros inseridos pelo utilizador.

Alínea B

Escreva um programa para ordenar três inteiros inseridos pelo utilizador.

Alínea C

Escreva um programa para ordenar quatro inteiros inseridos pelo utilizador.

Exercício 2 Construa um programa que verifica se um número é par ou impar, numero esse introduzido pelo utilizador.

Exercício 3 Crie um programa que leia dois números inteiros e informe o utilizador se o primeiro é divisível pelo segundo.

Exercício 4 Escreva um programa em Java que converta notas quantitativas de 0 a 20 em notas qualitativas de mau a excelente, utilizando uma estrutura de if’s encadeados e que verifique o limite superior das gamas de cada uma das notas qualitativas. Considere que: 0-4:Mau; 5-9:Mediocre; 10-13:Suficiente; 14-17:Bom; 18-20:Muito Bom.

Exercício 5 Escreva um programa em Java que aceite três nomes e os imprima por ordem alfabética crescente. Use o método comparedTo() da classe String. O método comparedTo() tem o seguinte comportamento: String s1=”CAPACIDADE”; String s2=”CAPAZ”; s1.comparedTo(s2) devolve um valor inteiro negativo. s2.comparedTo(s2) devolve 0. s2.comparedTo(s1) devolve um valor inteiro positivo.

Exercício 6 Utilizando a linguagem Java, crie um programa que receba do utilizador um número correspondente a um mês, e apresente no monitor o mês correspondente. (Nota: 1=JAN, 2=FEV, 3=MAR,…). Deve usar a instrução de selecção switch.

14/32 © DSI

Page 15: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício 7 Crie um programa, pede ao utilizador para introduzir dois números e a operação aritmética (*, /, -, +) que quer efectuar, pretende-se imprimir o resultado da operação matemática entre ambos.

Exercício 8 Escreva um programa que apresente uma lista de 5 livros diferentes ao utilizador, pedindo-lhe que seleccione um deles. Para o livro seleccionado, informe o utilizador do preço do livro.

Exercício 9 Desenvolva um programa que mostra ao utilizador o seguinte menu: 1 – Nome 2 – Idade 3 – Nacionalidade 4 – Sair E por fim, peça ao utilizador que introduza a opção que deseja visualizar e mostra qual foi essa opção escolhida. Use a intrução switch.

Exercício 10 Altere o exercicio anterior de forma a pedir os dados do utilizador no inicio do programa. No entanto, sempre que escolher uma das opções mostra os dados e de seguida pergunta se deseja alterar os dados dessa mesma opção. Caso o utilizador deseje alterar deve alterar e depois mostrar toda a informação do utilizador.

© DSI 15/32

Page 16: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série 5: Estruturas de Repetição (WHILE, DO-WHILE e FOR)

Objectivos da Série: Com esta série de problemas pretende-se que o aluno:

1. Pratique a utilização dos comandos while, do-while e for; 2. Domine a utilização das estruturas while, do-while e for nas suas várias formas.

Exercício 1 Escreva um programa, que analisa um número aleatório, informando se este é primo ou não.

Alínea A

Use a estrutura de repetição while.

Alínea B

Use a estrutura de repetição do-while.

Exercício 2 Crie um programa, em Java, que receba um número inteiro e informe quantos dígitos foram introduzidos.

Alínea A

Use a estrutura de repetição while.

Alínea B

Use a estrutura de repetição do-while.

Exercício 3 Escreva um programa que leia um conjunto de números inteiros e termine quando for introduzido um número negativo, indicando quantos números foram introduzidos e qual é o maior e o menor número introduzido. Use a estrutura do-while.

Exercício 4 Escreva um programa, que leia um número inteiro e calcule a soma dos seus dígitos. Use a estrutura while.

Exercício 5 Faça um programa que lê uma sequência de números inteiros positivos e calcule a sua soma. A quantidade de números é desconhecida à partida. A sequência de entrada só termina quando for introduzido um número zero. Use a estrutura do-while.

Exercício 6 Crie um programa que calcule a soma de n primeiros números positivos, sendo o valor de n fornecido pelo utilizador. Use a estrutura while.

Exercício 7 Faça um programa, que calcule a média de 5 números aleatórios. Use a estrutura for.

Exercício 8 Escreva um programa que imprima a soma dos primeiros 20 números ímpares. Use a estrutura for.

16/32 © DSI

Page 17: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício 9 Escreva um programa que peça ao utilizador que introduza um número inteior, e verifique se esse mesmo número inteiro é divisível por 1 até ao número introduzido. Use a estrutura for.

Exercício 10 Desenvolva um programa que mostra todos os números primos até 1000, por ordem decrescente. Use a estrutura for.

Exercício 11 Escreva um programa que gera aleatoriamente um número entre 1 e 100, e pede ao utilizador que acerte nesse número. Quando o utilizador introduz o número, deve indicar se este é maior ou menor ou igual ao gerado. O jogador tem 10 tentativas. Se o jogador acertar antes das tentativas terminarem deve indicar que o jogador ganhou e o número de tentativas que utilizou. Use a estrutura for.

© DSI 17/32

Page 18: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série 6: Métodos – Passagem de parâmetros

Objectivos da Série:

Com esta série de problemas pretende-se que o aluno: 1. Pratique a utilização da passagem de parâmetros. 2. Aprenda como interagir programas e subprogramas.

Exercício 1 Faça um programa para o cálculo da expressão f(x)=x + 2x + 10, para os vários valores de x. (Nota: considere x os primeiros 10 valores inteiros).

2

Exercício 2 Escreva um programa em que obtenha 2 números aleatórios, entre 1 e 20, e retorne o máximo entre ambos.

Exercício 3 Faça um programa que calcula o cubo dos primeiros 10 números inteiros.

Exercício 4 Faça um programa que leia três números inteiros e calcule a sua média. Recorra a um método para determinar a média pretendida.

Exercício 5 Escreva um método chamado sinal, que receba um número inteiro e retorne 1, -1 ou 0 caso o número seja maior, menor ou igual a zero, respectivamente.

Exercício 6 Escreva um programa, em Java, que contenha um método potência, que receba uma base e um expoente e calcule o valor da base elevado ao expoente. O expoente é sempre maior ou igual a zero e, a base é sempre representado por números inteiros positivos.

18/32 © DSI

Page 19: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série 7: Classes e Objectos

Objectivos da Série:

Com esta série de problemas pretende-se que o aluno: 1. Aprenda a criar e instanciar Classes. Variáveis e Métodos de Instâncias. 2. Aprenda como interagir entre Classes.

Exercício 1 Programa para registo e consulta de veículos automóveis para stand de usados.

a) Defina uma classe Automóvel, que tem a seguinte informação • Marca • Ano • Nº Série motor • Cor • Preço

b) Defina um método construtor para a classe Automóvel que inicializa os valores dos

atributos através da passagem de argumentos definidos na alínea a)

c) Defina os seguintes métodos a) getMarca – retorna o valor do atributo marca b) getAno – retorna o valor do atributo ano c) getSerie – retorna o valor do atributo Série d) getCor – retorna o valor do atributo Cor

d) Elabore um programa onde: • Na classe principal cria 2 automóveis, através da criação de objectos da classe

Automóvel. • Defina um método para preenchimento de dados sobre um automóveis.

e) Defina na classe principal os seguintes métodos:

• procuraMarca – lista o automóvel de uma determinada marca • listaAutomovel – lista as características do automóvel pelo seu nº de série.

f) Considere que se pretende trocar os atributos entre ambos automóveis. Para isso, crie um método para efectuar a troca pretendida. Para verificar os resultados, imprima os atributos dos automóveis, antes e depois da troca.

Nota : Recorra à passagem por referência no método para aceder e alterar os dados do objecto.

© DSI 19/32

Page 20: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios Exercício 2 Pretende-se criar uma conta bancária para dois clientes. Para isso, implemente um programa que permita:

1. Inserir os dados dos clientes. 2. Procurar o cliente através do seu número de contribuinte e imprimindo, em seguida,

os seus dados. Assim, pretende-se que:

a) Defina uma classe Cliente com a seguinte informação: • nome – nome do Cliente • n_Contribuinte – número do contribuinte • morada – Morada do cliente • telefone – Telefone/telemóvel para contacto

b) Na classe criada defina os seguintes métodos: • setNome – modifica o valor do atributo nome • getNome – retorna o conteúdo do atributo nome • setContribuinte - modifica o valor do atributo n_contribuinte • getContribuinte - retorna o conteúdo do atributo n_contribuinte • setMorada - modifica o valor do atributo morada • getMorada - retorna o conteúdo do atributo morada • setTelefone - modifica o valor do atributo telefone • getTelefone - retorna o conteúdo do atributo telefone c) Defina na classe principal os seguintes métodos: • Método para preenchimento dos dados do Cliente:

public static Cliente preencheDados()

• Método para procurar o cliente com base no seu número de contribuinte: public static Cliente FindCliente(Cliente first,Cliente second,int

contrib){

• Método para imprimir os resultados: public static void verificaCliente(Cliente testeCliente)

• Método main, onde invoque cada um dos métodos acima implementados. Exercício 3 Implemente um programa para registo e consulta de informação sobre os funcionários de uma empresa

a) Defina uma classe Funcionário que tem a seguinte informação: • nome – nome do Funcionário • n_Bi – nº do BI • categoria – categoria da função • ordenado – ordenado base

20/32 © DSI

Page 21: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

b) Defina um método constructor para a classe Funcionário que inicialize os valores dos atributos através da passagem de argumentos definidos na alínea a)

c) Defina os seguintes métodos

• getNome – retorna o valor do atributo nome • getBI – retorna o valor do atributo BI • getCategoria – retorna o valor do atributo categoria • getOrdenado – retorna o valor do atributo ordenado • setOrdenado – modifica o valor do atributo ordenado • setCategoria – modifica o valor do atributo categoria

d) Elabore uma classe principal onde :

• Crie 2 funcionários, através da criação de objectos da classe Funcionário • Defina um método para preenchimento dados de um funcionário que retorne o

objecto preenchido. e) Defina na classe principal os seguintes métodos

• procura Funcionário – lista os atributos do funcionário pelo seu nº de BI • calculaOrdenado – para um determinado funcionário calcula o seu ordenado

líquido, supondo que desconta 11% para a Segurança Social, 20% para o IRS e 15 EUR para a quota associativa da empresa.

• calculaTotalOrdenado – determina qual o montante total que a empresa despende com ordenados dos dois funcionários por mês.

© DSI 21/32

Page 22: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série 8: Métodos Recursivos

Objectivos da Série:

Com esta série de problemas pretende-se que o aluno: 1. Pratique a utilização dos métodos recursivos.

Exercício 1 Utilizando a recursividade, obtenha os primeiros 12 números da sequência de Fibonacci.

Exercício 2 A função seno(x) pode ser calculada somando os n primeiros termos da séria infinita, dado n que é um inteiro e x um número real, tal como se exprime na figura 1.

Sen(x) = !

....!9!7!5!3

9753

nxxxxxx

n

−+−+−

Figura 1

Os valores de x são expressos em radianos. a) Escreva uma função que calcule iterativamente o sen(x). b) Escreva uma função que calcule recursivamente o sen(x).

Exercício 3 Sabe-se que a divisão pode ser obtida através de uma série de subtracções. Escreva uma função recursiva, de dois argumentos inteiros, chamada divisão, que retorne o resultado da divisão inteira do primeiro argumento pelo segundo. A função apenas pode utilizar as operações de adição e subtracção.

Exercício 4 O máximo divisor comum entre dois números pode ser calculada por : n1 se n2=0 mdc(n1,n2) = mdc(n2,mod(n1,n2)) se n2<>0

Figura 2

Escreva um programa que leia 2 números inteiros e calcule o seu mdc.

Exercício 5 Faça um programa que, utilizando o método recursivo, implemente o triângulo de Pascal. O Triângulo de Pascal é dado pela seguinte expressão: 1 se k=0 ou k=n C(n,k) = C(n-1,k) + c(n-1,k-1) se 0<k<n

Figura 3

22/32 © DSI

Page 23: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Resultado pretendido: 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 1 6 15 20 15 6 1 1 7 21 35 35 21 7 1 1 8 28 56 70 56 28 8 1

Exercício 6 Escreva o seguinte método recursivo que retorne a sequência de n termos referentes ao número triangular.

static long t(int n) Os números triangulares são 0 1 3 6 10 15 21 28 ... e são dados pela expressão seguinte:

t(n) = t(n-1) + n para n > 1

© DSI 23/32

Page 24: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série 9: Tabelas

Objectivos da Série:

Com esta série de problemas pretende-se que o aluno: 1. Pratique aprofundadamente o uso das instruções de repetição 2. Aprenda a definir, inicializar, e manipular tabelas de tipos primitivos. 3. Domine o uso de tabelas unidimensionais e multi-dimensionais. 4. Saiba definir tabelas de objectos e efectuar operações sobre as mesmas

Exercício nº 1 Implemente o método soma que retorna a soma dos elementos se uma tabela. A assinatura do método é a que se segue:

static double soma(double[] x)

Exercício nº 2 Implemente o método para tabelas que troca entre si os elementos da tabela t da posição i e j, tendo em conta a seguinte assinatura: static void troca(int[] t, int i, int j)

Exercício nº 3 Implemente o método mover, com a assinatura abaixo descrita, que move o elemento da tabela t da posição i para a posição j Exemplo: Se t representa a lista {22,33,44,55,66,77}, então mover(v,4,1) resulta em {22,66,33,44,55,77} static void mover(int[] t, int i, int j)

Exercício nº 4 Implemente uma classe que contenha os dois métodos acima definidos e que o método “main” permita testar o método troca e o método mover.

Exercício nº 5 Considere a seguinte declaração: char[][] m={{‘c’,’f’,’a’}, {‘q’,’q’,’w’},{‘i’,’p’,’j’}};

Alínea a

Qual a dimensão da tabela m ?

24/32 © DSI

Page 25: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Alínea b

Quantos elementos tem a tabela m?

Alínea c

Qual o tipo dos elementos da tabela ?

Exercício nº 6

Alinea a

Implemente o método trianguloDePascal que calcula e mostra no ecran as n primeiras linhas do triângulo de Pascal. As linhas do triângulo de pascal calculam-se colocando no primeiro e último elemento de cada linha 1 e nos restantes elementos a soma dos elementos da linha anterior na posição imediatamente antes e depois do elemento que estamos a calcular. Exemplo de um Triângulo de Pascal de dimensão 6:

[0] [1] [2] [3] [4] [5]

[0] 1

[1] 1 1

[2] 1 2 1

[3] 1 3 3 1

[4] 1 4 6 4 1

[5] 1 5 10 10 5 1

A assinatura do método a implementar é a que se segue:

static int[][] trianguloDePascal(int n)

Alinea b

Implemente uma classe que contenha o método trianguloDePascal e que permita testá-lo (pedindo o valor n ao utilizador e escrevendo no ecran o triângulo de pascal correspondente)

Exercício nº 7 Implemente o método produtoExterno que calcula o produto externo entre dois vectores. A matriz resultante calcula-se da seguinte forma p[i][j]=x[i]*y[j], onde x e y são os vectores de entrada static double[][] produtoExterno(double[] x, double[] y)

© DSI 25/32

Page 26: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício nº 8 Temos um sistema para validar as matrizes do totoloto. O sistema digitaliza os impressos e converte cada aposta numa matriz de booleanos de 7 x 7. Cada elemento da matriz corresponde um número de 1-49 e se este tiver o valor lógico verdade significa que o número correspondente faz parte da aposta: Exemplo:

Esta aposta do totoloto 1 2 3 4 5 6 7 8 9 10 11 12 13 1415 16 17 18 19 20 2122 23 24 25 26 27 2829 30 31 32 33 34 3536 37 38 39 40 41 4243 44 45 46 47 48 49

Corresponde a esta matriz

T F F F F F F F F T F F F F F F F T F F F F F F F F F F F F F F T T F F F F F F F F T F F F F F F

Alinea a

Escreva um método que, tendo a assinatura abaixo descrita, receba como entrada a matriz de aposta e devolva uma tabela com os números apostados: static int[] apostaTotoloto(boolean[][] m)

Alinea b

Escreva um método que receba como entrada a matriz de aposta e devolva um valor do tipo boolean que diz se esta é valida. Nota: poderá haver apostas múltiplas, com 7,8,9,10,11, e 12 números static boolean apostaValidaTotoloto(boolean[][] m)

Alinea c

Escreva um programa que peça ao utilizador a sua aposta do totoloto e verifique se esta é válida e caso não seja, dê uma mensagem de erro.

Exercício nº 9 Treinando álgebra de matrizes.... Implemente um método que multiplique duas matrizes de inteiros. static int[ ][ ] produtoMatrizes(int[ ][ ] m1, int[ ][ ]m2)

26/32 © DSI

Page 27: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício nº 10 Treinando álgebra de matrizes.... Implemente um método que verifique se a matriz dada é a matriz identidade. static boolean identidadeMatriz(int[ ][ ] m1)

Exercício nº 11 Treinando álgebra de matrizes.... Implemente um método que dado uma matriz calcula a matriz transposta. static int[ ] [ ] transpostaMatriz(int[ ][ ] m1)

Exercício nº 12 Programa para introdução e consulta de veículos automóveis para um stand .

a) Defina uma classe Automóvel, com os atributos • Marca • Nº Série motor • Cor • Preço

b)Defina um método construtor para a classe Automóvel que inicializa os valores dos atributos através da passagem de argumentos definidos na alínea a) c)Defina os seguintes métodos

• getMarca – retorna o valor do atributo marca • getPreço – retorna o valor do atributo preço • getSerie – retorna o valor do atributo Série • getCor – retorna o valor do atributo Cor

d)Crie uma Classe Menus onde deve ser possível:

• Introduzir Automóveis na Base de dados • Listar dados dos automóveis respectivos através da inserção do número de série • Listar dados dos automóveis respectivos através da inserção da marca

e)Defina na classe de teste, uma Base de dados com informação de automóveis, através da criação de uma tabela de objectos da classe Automóvel

© DSI 27/32

Page 28: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Série Nº10– Procura e Ordenação de elementos em tabelas

Objectivos da Série:

Com esta série de problemas pretende-se que o aluno: 1. Pratique o uso do comando o uso de tabelas e da passagem de tabelas como

parametros 2. Aprenda a implementar algoritmos de procura 3. Domine algoritmos de procura e uso de tabelas 4. Aprenda a implementar algoritmos de ordenação 5. Domine a ordenação de tabelas segundo vários métodos

Exercício nº 1 Implemente o método minimo retorna o menor valor dos elementos da tabela x.

static double minimo(double[] x)

Exercício nº 2 Implementa o método iMaximo que retorna o indice do elemento de maior valor da tabela x:

static int iMaximo(double[] x)

Exercício nº 3 Implementa o método gama que retorna a diferença entre o valor mínimo e o valor máximo dos elementos da tabela x.

static double gama(double[] x)

Exercício nº 4 Implementa o método iguais que retorna o valor lógico verdade se as duas tabelas forem iguais, ou seja se os valores dos elementos dos dois vectores corresponderem entre si: static boolean iguais(double[] x , double[] y)

Exercício nº 5 Implemente a classe TabelaTeste, que contenha os métodos definidos em 1, 2 e 3. Esta classe deve ainda conter um método main, que:

1. Implemente a leitura das duas tabelas. 2. Imprima no ecran os seguintes resultados: • O mínimo dos valores da 1ª e 2ª tabela • A gama de valores da 1ª e 2ªa tabela • Se as duas tabelas são iguais.

Exercício nº 6 Temos uma tabela com as temperaturas médias ao longo dos dias de mês. Queremos saber para um determinado mês:

1. Qual foi a temperatura mais baixa

28/32 © DSI

Page 29: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

2. Em que dia ocorreu a temperatura mais elevada 3. Qual foi a diferença entre a temperatura mais baixa e a temperatura mais alta. Implemente um programa que cumpra os requisitos acima descritos usando os métodos definidos no Exercícios 1, 2, 3.

Exercício nº 7

Alinea a

Implemente o método procuraInteiro que procura na tabela v, que tem como critério de paragem o valor de s, se esta contém o elemento x. Caso a procura seja realizada com sucesso retorna o índice do elemento, senão retorna –1.

public static int procuraInteiro(int[] v, int x, int s)

Alinea b

Implemente o método leInteiro que retorna uma tabela com os inteiros introduzidos, através do teclado. O último elemento tem o valor s. Sendo assim, quando o utilizador digitar o valor de s é porque a introdução de valores terminou. public static int[] leInteiro(int s)

Alinea c

Modifique o método da alínea a) de modo a poder ser feita procura em parte da lista, ou seja procura na tabela v entre os indices inicio e fim, do elemento x. Tendo como critério de paragem o valor s. Caso a operação seja realizada com sucesso retorna o índice do elemento, senão retorna o valor –1. public static int procuraInteiro(int[] v, int x, int s, int inicio, int fim)

Alinea d

Implemente um programa que : 1. Leia a nota dos trabalhos de IP por grupo. 2. Pergunte ao utilizador qual a nota que pretende saber: 3. Imprima o nº dos grupos que tiveram a nota lida no ponto 2

Nota: Utilize os métodos definidos anteriormente

Exercício 8. Um sistema de controlo de presenças ligado ao sistema de marcação de ponto, mantém uma lista de todos os trabalhadores que num determinado momento se encontram dentro da empresa. É necessário implementar um método que dado o nome de uma pessoa, ele nos valide se esta pessoa se encontra dentro da empresa ou não. Utilize a procura binária na implementação desta função. Nota: a lista é terminada com a palavra “ * ‘” public static boolean procuraPessoa(String[] v)

© DSI 29/32

Page 30: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício 9 Existe um sistema informático na escola para inscrição dos alunos para os testes de I.P. O programa pede aos alunos que se inscrevem o número e o nome . Após as inscrições terem terminado o programa disponibiliza várias funcionalidades:

1. Conta o nº de alunos inscritos 2. Imprime no ecran o nº de aluno e o seu nome por ordem crescente do nº de aluno.

Alínea a

Implemente um método que permita contar o nº de alunos inscritos

Alínea b

Implemente um método que permita ordenar ,usando o algoritmo selecion sort, os alunos por número na ordem crescente. Nota. Deverá ser mantida a correspondência entre nº de aluno e nome.

Alínea c

Implemente o programa descrito acima usando os métodos que implementou na alínea a) e na alínea b).

Exercício 10 Implemente um programa que:

• Ordene usando o algoritmo BubbleSort a matriz:

loxjbgdfa

• Apresente a matriz ordenada em ordem crescente da esquerda para a direita e de

baixo para cima no ecran, devendo ser o resultado final obtido:

xoljgfdba

30/32 © DSI

Page 31: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício 11 Implemente um programa que:

1. receba o registo de emails (nome e morada) 2. guarde estes registos numa tabela 3. Ordene a tabela por nome, segundo o método quicksort. 4. Apresente em seguida o resultado no ecran.

Exercício 12

Os procedimentos de ordenação apresentados nesta série correspondem a uma ordenação destrutiva, pois a tabela original é destruída e substituída pela tabela ordenada. Um processo alternativo consiste em criar uma tabela com índices, que representam as posições ordenadas dos elementos por selecção, criando uma tabela com índices. Implemente um método para efectuar a ordenação por selecção, criando uma tabela com índices.

Exercício 13

A aplicação CarrosUsados é uma aplicação para busca de informação sobre carros usados. Contém informação sobre o modelo do carro, marca , ano e preço. Permite realizar as seguintes opções:

1. Listagem ordenada por modelo 2. Listagem ordenada por marca 3. Listagem ordenada por ano 4. Listagem ordenada por preço 5. Listagem ordenada por modelo, marca, preço 6. Listagem ordenada por modelo, marca, ano

public class CarrosUsados {

public String marca, modelo; public int ano,preco; …

}

Alínea a

Defina o método que implementa a ordenação da tabela de carros usados por modelo.

Alínea b

Defina o método que implementa a ordenação da tabela de carros usados por preço.

Alínea c

Defina o método que implementa a ordenação da tabela primeiro por modelo, segundo por marca, terceiro por preço.

© DSI 31/32

Page 32: Series lab

Séries de Exercícios de Introdução à Programação – Laboratórios

Exercício nº 14 Uma loja pretende dispor os seus artigos de vestuário segundo cores. Para isso precisa de fazer uma pequena alteração à aplicação de suporte à gestão da loja, de modo a acrescentar a funcionalidade de listagem de artigos por ordem de cor . Sendo a ordem de cores desejada (amarelo,laranja,castanho,beje,verde,azul,vermelho,cinzento,preto). Implemente o método que permite reordenar a tabela de objectos ArtigoVestuario segundo a ordem de cores desejada public class ArtigoVestuario {

public int cod; public String artigo, cor;

... }

Exercício nº 15 Pretende-se ordenar objectos da classe Data. Esta classe contém os campos dia,mês e ano.

Alínea a

Ecreva a declaração para a classe Data.

Alínea b

Escreva a declaração para uma tabela de tamanho 100 , cujos elementos são da classe Data.

Alínea c

Implemente o método ordenaData que ordena de forma crescente ou decrescente uma tabela de objectos da classe Data

32/32 © DSI