Baixe o app para aproveitar ainda mais
Prévia do material em texto
APOL 2 - Lógica de Programação e Algoritmos Questão 1/10 - Lógica de Programação e Algoritmos Na AULA 4 você aprendeu o laço while e o laço for. A seguir você está vendo um laço implementado com while. Assinale a alternativa que, CORRETAMENTE, gera a mesma saída que o código apresentado, mas agora implementando com laço for. Nota: 10.0 A Você acertou! O valor inicial é 88. O valor final do iterador deve ser ZERO. Porém, como o for sempre vai até o valor final colocado MENOS UM, neste caso devemos colocar -1 ali para irmos até zero. Passo é de -4. B C D E Questão 2/10 - Lógica de Programação e Algoritmos Na AULA 4 aprendemos o conceito de estrutura de repetição. Sobre este conteúdo, analise as afirmativas a seguir: I - Estruturas de repetição tem como um de seus objetivos o de auxiliar na redução da quantidade de APOL 2 - Lógica de Programação e Algoritmos instruções redundantes em um algoritmo. II - Estruturas de repetição são também chamadas de estruturas iterativas, ou de laço de repetição. III - Uma estrutura de repetição é uma recurso em programação que faz com que todas as instruções dentro dela se repitam de maneira indefinida, até que uma condição seja satisfeita. IV - Existe uma só maneira de criarmos estruturas de repetição em linguagem Python, que seria a estrutura chamada de while (ou enquanto, em pseudocódigo). Acerca das afirmativas apresentadas, assinale somente a alternativa contendo as corretas: Nota: 10.0 A I e II, apenas. B I, II e III, apenas. Você acertou! A afirmativa IV está incorreta porque temos 2 estruturas em Python para repetição: while e for. C I e III, apenas. D I e III e IV, apenas. E I, II, III e IV. Questão 3/10 - Lógica de Programação e Algoritmos Suponha que você precisa criar uma função que recebe alguns dados como parâmetro para um cadastro de pessoas: o nome da pessoa, o ano de nascimento, o salário (com valor padrão de R$ 1000) e o sexo (com valor padrão 'F'). Assinale a alternativa que contém a definição correta para esta função exemplificada em linguagem Python. Nota: 10.0 A def cadastro(nome, ano, salario = , sexo = 0): B def cadastro(nome, ano, salario, sexo = 'F'): C def cadastro(nome, ano, salario = 1000, sexo = 'F'): Você acertou! D def cadastro(nome, ano, salario, sexo): E def cadastro(nome, ano, salario = 1000, sexo): Questão 4/10 - Lógica de Programação e Algoritmos Na AULA 5 você aprendeu a criar funções e também a realizar a passagem de parâmetros em funções. Acerca deste assunto, analise as afirmativas a seguir: I - Parâmetros são dados recebidos pelas funções e oriundos do programa principal ou mesmo de outra função. APOL 2 - Lógica de Programação e Algoritmos II - O ato de enviar um dado para um função é chamado de passagem de parâmetro. III - Um função só pode receber um único parâmetro. Acerca das afirmativas mostradas, assinale somente as CORRETAS: Nota: 10.0 A I, apenas. B II, apenas. C III, apenas. D I e II, apenas. Você acertou! III - uma função pode receber diversos parâmetros. E I e III, apenas. Questão 5/10 - Lógica de Programação e Algoritmos Na AULA 5 aprendemos sobre o escopo de variáveis e também sobre passagem de parâmetros. Sobre este assunto, observe o código a seguir: No código apresentado o programa principal invoca uma função chamada 'parangaricu', sem parâmetros, que por sua vez invoca outra função de nome 'tirimirruaro', esta com um parâmetro. Observe que no código apresentado temos 2 linhas de print comentadas (linha 7 e linha 10). Supondo que somente uma das linhas seja habilitada no código por vez, assinale a alternativa que corretamente contém a saída do programa para cada um dos prints, e o motivo correto que gerou esta saída. Nota: 10.0 A Linha 7. Saída: parangaricutirimirruaro. Linha 10. Saída: parangaricutirimirruaro. APOL 2 - Lógica de Programação e Algoritmos Justificativa: a variável 'palavra2' é local da função 'tirimirruaro', portanto só existe dentro desta função. Por este motivo, o print dentro de 'tirimirruaro' funcionou concatenando as strings. Já o print no programa principal também retorna a mesma resposta porque o print está sendo realizado no escopo global. B Linha 7. Saída: tirimirruaro. Linha 10. Saída: parangaricutirimirruaro. Justificativa: a variável 'palavra2' é local da função 'tirimirruaro', porém a variável 'palavra' é local de outra função, não sendo possível acessar seu valor dentro da função 'tirimirruaro'. Por este motivo, o print dentro de 'tirimirruaro' funcionou somente mostrando a parte acessível que é 'tirimirruaro'. Já o print no programa principal retorna a concatenação das strings porque está no escopo global. C Linha 7. Saída: parangaricutirimirruaro. Linha 10. Saída: Erro (NameError). Justificativa: a variável 'palavra2' é global do programa. Porém, como ela não recebeu nenhuma atribuição no escopo global, um erro acontece. D Linha 7. Saída: parangaricutirimirruaro. Linha 10. Saída: Erro (NameError). Justificativa: a variável 'palavra2' é local da função 'tirimirruaro', portanto só existe dentro desta função. Por este motivo, o print dentro de 'tirimirruaro' funcionou concatenando as strings. Já o print no programa principal não funcionou porque ele não conhece a variável do escopo local. Você acertou! Questão 6/10 - Lógica de Programação e Algoritmos Na AULA 5 aprendemos que a ordem dos parâmetros faz a diferença no momento da passagem. Observe o código a seguir para calcular uma divisão de dois valores. Assinale a alternativa que contém a chamada a função que CORRETAMENTE resultaria em 0,3 no resultado da divisão. Nota: 10.0 A div2(den = 3, 10) B div2(3, num = 10) C div2(den = 3, num = 10) APOL 2 - Lógica de Programação e Algoritmos D div2(3, 10) Você acertou! E div2(10, 3) Questão 7/10 - Lógica de Programação e Algoritmos Na AULA 4, você aprendeu a trabalhar com o laço for. Suponha que você precisa realizar o print na tela de valores numéricos iniciando no 7 e imprimindo até o 25, de 3 em 3. Assinale a alternativa que contém o laço for que realize o que está sendo proposto no enunciado. Nota: 10.0 A B C D Você acertou! Esta é a correta, pois lembre que para irmos até 25, devemos colocar até 26, pois o for faz iterações até o valor ali colocado menos um. E Questão 8/10 - Lógica de Programação e Algoritmos Aprendemos a trabalhar na AULA 4 com estruturas de repetição aninhadas. Observe o código a seguir que contém um exemplo disso empregando dois laços for. APOL 2 - Lógica de Programação e Algoritmos Acerca deste código, assinale a alternativa que contém uma afirmação CORRETA sobre este código. Nota: 10.0 A O laço de repetição for interno será executado 10 vezes ao longo da execução de todo o programa. O laço interno é executado 10 x 10 = 100 vezes B O print do resultado para i = 3 e j = 5 será o valor 2. i + j = 8 C Se alterássemos o laço for externo para um do tipo while, a linha de código corresponde ao laço poderia ser: while(x < 20). Sendo necessário também a inclusão de mais duas linhas para inicialização e incremento da variável de controle. Você acertou! Correto. É claro que para funcionar com o while seria necessário acrescentar outras duas linhas, uma contendo a inicialização da variãvel e outra incrementando. Porém, a linha solicitado está corretamente alterada para um while D O laço de repetição externo trabalha com um passo de 20. Passo é unitário, pois foi omitido. E O laço de repetição interno trabalha com um passo unitário. Passo é 2. Questão 9/10 - Lógica de Programação e Algoritmos Na AULA 6 aprendemos 3 estruturas de dados: tuplas, listas e dicionários. Acerca das características destas estruturas de dados, assinalea alternativa CORRETA: Nota: 10.0 A Dicionários, assim como tuplas, são imutáveis, ou seja, uma vez criadas, não podem ser alteradas. B Uma estrutura de dados dinâmica é aquela que aloca somente a quantidade de memória que precisa, e que pode alterar seu tamanho e seus dados de acordo com sua necessidade. Você acertou! C Uma estrutura de dados estática é aquela em que todos os dados armazenados dentro dela não podem ser copiados para outras variáveis. APOL 2 - Lógica de Programação e Algoritmos D Uma tupla é uma estrutura de dados estática. Isso significa que seus dados podem ser alterados sempre que necessário. E Uma lista é uma estrutura de dados estática. Isso significa que seus dados não podem ser alterados uma vez criada a estrutura. Questão 10/10 - Lógica de Programação e Algoritmos Na AULA 4 aprendemos a trabalhar com as instruções de break e continue dentro dos laços de repetição. Sobre este assunto, analise as afirmativas a seguir: I - A instrução continue é capaz de fazer com que o laço de repetição garanta que a próxima iteração irá acontecer, pois ele ignora o próximo teste lógico do loop. II - A instrução break é capaz de fazer o loop retornar ao seu inicio, recomeçando o laço. III - É permitido combinarmos estruturas de break e continue dentro de um mesmo laço de repetição Acerca das afirmativas apresentadas, assinale somente as CORRETAS: Nota: 10.0 A I, apenas. B II, apenas. C III, apenas. Você acertou! D I e III, apenas. E II e III, apenas.
Compartilhar