Logo Passei Direto
Buscar

Lista de Exercícios 2

User badge image

Enviado por Giovani de Lima em

Esta é uma pré-visualização de arquivo. Entre para ver o arquivo original

Lista 2 - CI055 - Algoritmos e Estruturas de Dados I
Instruc¸o˜es de soluc¸a˜o e entrega do trabalho
A lista abaixo deve ser resolvida de maneira individual. As soluc¸o˜es dos exerc´ıcios devera˜o ser discutidas
e entregues por e-mail ao tutor do seu Grupo de Estudos ate´ o dia 22 de setembro (domingo) para que fique
registrado o seu trabalho na forma de frequeˆncia adicional. Tal como explicado em sala de aula, esse cre´dito de
frequeˆncia sera´ importante na avaliac¸a˜o formativa do aluno e pode influenciar a avaliac¸a˜o geral. Para facilitar
a entrega, envie todos os arquivos em apenas um e-mail, seguindo as instruc¸o˜es abaixo:
1. Fac¸a cada programa em um arquivo separado com extensa˜o .pas e garanta que os co´digos-fonte sejam
compat´ıveis com o dialeto fpc (Free Pascal Compiler);
2. Coloque todos os programas em um direto´rio exclusivo, assim, por exemplo, se o seu nome de usua´rio no
sistema fosse grs13 voceˆ deveria colocar todos os arquivos .pas (e apenas os de extensa˜o .pas ) em um
direto´rio chamado lista2-grs13;
3. Empacote e comprima esse direto´rio com os comandos abaixo para criar o arquivo lista2-grs13.tar.gz
(voceˆ precisa de um terminal virtual do Linux com o prompt de comando no contexto do n´ıvel imediata-
mente superior ao direto´rio lista2-grs13):
tar cf lista2-grs13.tar lista2-grs13
gzip lista2-grs13.tar
4. Finalmente, anexe o arquivo lista2-grs13.tar.gz em um e-mail e envie-o ao tutor do seu Grupo de
Estudos.
Enunciados dos exerc´ıcios
1. Fazer um programa em Pascal capaz de ler apenas um nu´mero inteiro positivo do teclado, de calcular a
decomposic¸a˜o em fatores primos desse nu´mero e de imprimir os fatores calculados. Exemplos de entrada
e sa´ıda sa˜o:
./fatores_primos
12 <ENTER>
2 2 3
./fatores_primos
150 <ENTER>
2 3 5 5
2. Considere a soma S dos termo da se´rie infinita apresentada abaixo, a qual e´ responsa´vel pelo ca´lculo do
valor do co-seno de 1 (um) radiano:
S = 1− 12! + 14! − 16! + 18! − 110! + 112! − ...
Fazer um programa em linguagem Pascal que seja capaz de calcular o valor aproximado da soma (S) dos
termos da se´rie ate´ o momento em que a diferenc¸a em norma (mo´dulo) entre 2 termos consecutivos for
menor que 0,000001.
3. Fazer um programa em Pascal capaz de ler apenas um nu´mero inteiro positivo do teclado e de verificar
se a sua sequeˆncia de d´ıgitos e´ exatamente a mesma, tanto se for visto da esquerda para a direita quanto
da direita para a esquerda. Caso seja, imprimir ”Sim eh palindromo”. Caso na˜o seja, imprimir ”Nao eh
palindromo”. Dica: aplique diviso˜es sucessivas por 10. Exemplos de entrada e sa´ıda sa˜o:
./eh_palindromo
12321 <ENTER>
Sim eh palindromo
./eh_palindromo
31527 <ENTER>
Nao eh palindromo
4. Dizemos que uma sequeˆncia de inteiros e´ k-alternante se for composta alternadamente por segmentos de
nu´meros pares de tamanho k e segmentos de nu´meros ı´mpares de tamanho k. Exemplos:
A sequeˆncia 1 3 6 8 9 11 2 4 1 7 6 8 e´ 2-alternante.
A sequeˆncia 2 1 4 7 8 9 e´ 1-alternante.
A sequeˆncia 4 2 3 1 6 4 2 9 na˜o e´ alternante.
A sequeˆncia 1 3 5 e´ 3-alternante.
Fazer um programa em Pascal capaz de ler os seguintes valores de entrada:
a) um nu´mero inteiro k positivo que representa o tamanho do seguimento alternante que sera´ usado
para testar a sequeˆncia;
b) uma sequeˆncia de nu´meros inteiros positivos terminada por zero (o zero na˜o faz parte da sequeˆncia).
O programa deve determinar se a sequeˆncia de nu´meros lidos e´ k-alternante. Se for, o programa deve
imprimir ”Sim eh k-alternante”. Caso contra´rio, deve ser impressa a mesagem ”Nao eh k-alternante”.
Exemplos de entrada e sa´ıda sa˜o:
./eh_k_alternante
2 <ENTER>
1 3 6 8 9 11 2 4 1 7 6 8 0 <ENTER>
Sim eh k-alternante
./eh_k_alternante
3 <ENTER>
4 2 8 3 1 7 6 4 6 2 9 7 0 <ENTER>
Nao eh k-alternante
2

Teste o Premium para desbloquear

Aproveite todos os benefícios por 3 dias sem pagar! 😉
Já tem cadastro?