Ponteiros - Dredd

Fazer download em pdf ou txt
Fazer download em pdf ou txt
Você está na página 1de 16

29/01/2018 Dredd - Juiz Online

Dredd - Juiz Online


Principal Perfil Minhas Provas Sair

Minutos
Restantes:
6541 Exercícios de Alocação Dinâmica e
Usuário:
Leonardo
Ponteiros
Henrique de Braz

Notas:
Prova Aberta Até: 03/02/2018 07:00:00
Q1: 100
Q2: 100 Número Máximo de Tentativas: 6
Q3: 95
Q4: 100
Q5: 68.6 Atenuação da Nota por Tentativa: 5%
Q6: 39.5
Q7: 100
Q8: ? Instruções para a prova: Exercícios de Alocação Dinâmica e Ponteiros para
Q9: ? todas as turmas de IAlg. Pode ser acessado de casa.
Q10: ?
Q11: ?
Q12: ?
Q13: ?
Q14: ? Questão 1: Ponteiros - Subtração de vetores de caractere
Q15: ?
Total: 40

Escreva um programa que leia duas cadeias de caracteres e altere a


primeira cadeia para retirar todos os caracteres que estão também na
segunda cadeia. As duas cadeias de entrada devem ser declaradas
como vetores de char alocados dinamicamente.

No final, a primeira cadeia de caracteres resultante deve ser copiada


para um vertor de caracteres alocado dinamicamente com o tamanho
exato. Todas alocações de vetores do programa devem ser dinâmicas.

Entradas:

1. Numero de elementos do primeiro vetor


2. Elementos do primeiro vetor
3. Numero de elementos do segundo vetor
4. Elementos do segundo vetor

Saídas:

1. Vetor resultante com os caracteres do primeiro vetor que não


se encontram no segundo.

Exemplo de Entrada:

10
q w e r t y u i o p
9
m n b v c x z q w

Exemplo de Saída:

e r t y u i o p

https://dredd.dcc.ufla.br/testTrials.php#p703 1/16
29/01/2018 Dredd - Juiz Online

Peso: 1

Última tentativa realizada em: 19/12/2017 14:38:30

Tentativas: 1 de 6

Nota (0 a 100): 100


Minutos
Restantes: Status ou Justificativa de Nota: Nenhum erro encontrado.
6541

Usuário: Ver Código da Última Tentativa


Leonardo
Henrique de Braz Nova Resposta:
Notas:
Q1: 100
Selecione o arquivo com o código fonte do programa que resolve o
Q2: 100 problema para enviá-lo.
Q3: 95
Q4: 100
Q5: 68.6 Escolher arquivo Nenhum arquivo selecionado Enviar Resposta
Q6: 39.5
Q7: 100
Q8: ?
Q9: ?
Q10: ?
Q11: ?
Q12: ?
Q13: ?
Q14: ? Questão 2: Ponteiros - Hidrocarboneto
Q15: ?
Total: 40

Um hidrocarboneto é um composto químico formado por átomos de


carbono e hidrogênio. Faça um programa que crie um registro
chamado Hidrocarboneto contendo os campos inteiros C e H usados
para guardar a quantidade de carbonos e hidrogênios,
respectivamente, de um hidrocarboneto. No subprograma principal
aloque dinamicamente um registro Hidrocarboneto e peça ao usuário
as quantidades de carbono e hidrogênio do mesmo. Sabendo que
massa molecular do carbono é 12 e do hidrogênio é 1, seu programa
deverá calcular e exibir a massa molecular do composto.

Entradas:

1. Quantidade de carbonos do hidrocarboneto.


2. Quantidade de hidrogênios do hidrocarboneto.

Saídas:

1. Massa molecular do hidrocarboneto.

Exemplo de Entrada:

1 4

Exemplo de Saída:

16

Peso: 1

https://dredd.dcc.ufla.br/testTrials.php#p703 2/16
29/01/2018 Dredd - Juiz Online

Última tentativa realizada em: 19/12/2017 15:10:05

Tentativas: 1 de 6

Nota (0 a 100): 100

Status ou Justificativa de Nota: Nenhum erro encontrado.


Minutos
Restantes:
Ver Código da Última Tentativa
6541

Usuário:
Nova Resposta:
Leonardo
Henrique de Braz Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.
Notas:
Q1: 100
Q2: 100 Escolher arquivo Nenhum arquivo selecionado Enviar Resposta
Q3: 95
Q4: 100
Q5: 68.6
Q6: 39.5
Q7: 100
Q8: ?
Q9: ?
Q10: ?
Q11: ? Questão 3: Ponteiro - Procurando o elemento.
Q12: ?
Q13: ?
Q14: ?
Q15: ?
Total: 40
Escreva um programa que aloque dinamicamente uma matriz de
inteiros.As dimensões da matriz deverão ser lidas do usuário.Em
seguida, escreva uma função que receba um valor e retorne 1, caso o
valor esteja na matriz, ou retorne 0, no caso contrário.

Entradas:

1. Quantidade de linhas e colunas(int).


2. Elementos presentes na Matriz(int).
3. Elemento a ser procurado na Matriz(int).

Saídas:

1. 1, caso o valor esteja na matriz, ou 0, no caso contrário.

Exemplo de Entrada:

3 3
3 5 8
1 2 9
6 7 10
2

Exemplo de Saída:

Peso: 1

Última tentativa realizada em: 19/12/2017 17:25:24

Tentativas: 2 de 6

https://dredd.dcc.ufla.br/testTrials.php#p703 3/16
29/01/2018 Dredd - Juiz Online

Nota (0 a 100): 95

Status ou Justificativa de Nota: Nenhum erro encontrado.

Ver Código da Última Tentativa

Nova Resposta:
Minutos Selecione o arquivo com o código fonte do programa que resolve o
Restantes: problema para enviá-lo.
6541

Usuário: Escolher arquivo Nenhum arquivo selecionado Enviar Resposta


Leonardo
Henrique de Braz

Notas:
Q1: 100
Q2: 100
Q3: 95
Q4: 100
Q5: 68.6
Q6: 39.5
Questão 4: Ponteiros - Somando colunas
Q7: 100
Q8: ?
Q9: ?
Q10: ? Escreva uma função que receba como parâmetro uma matriz A 5 x 5
Q11: ? de inteiros. A função deve retornar o ponteiro para um vetor B de
Q12: ? tamanho 5 alocado dinamicamente, em que cada posição de B é a
Q13: ?
Q14: ?
soma dos números da coluna correspondente da matriz A.
Q15: ?
Total: 40 Entradas:

1. Os elementos da matriz A

Saídas:

1. Os elementos do vetor B

Exemplo de Entrada:

1 2 3 4 5
5 4 3 2 1
1 1 1 1 1
2 2 2 2 2
9 8 7 6 5

Exemplo de Saída:

18 17 16 15 14

Peso: 1

Última tentativa realizada em: 19/12/2017 17:35:02

Tentativas: 1 de 6

Nota (0 a 100): 100

Status ou Justificativa de Nota: Nenhum erro encontrado.

https://dredd.dcc.ufla.br/testTrials.php#p703 4/16
29/01/2018 Dredd - Juiz Online

Ver Código da Última Tentativa

Nova Resposta:
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta


Minutos
Restantes:
6541

Usuário:
Leonardo
Henrique de Braz

Notas: Questão 5: Ponteiro - Mês do Ano


Q1: 100
Q2: 100
Q3: 95
Q4: 100 Escreva uma função que recebe um inteiro entre 1 e 12 e retorna o
Q5: 68.6
Q6: 39.5
nome do mês correspondente. O retorno deve ser na função em si e
Q7: 100 não num dos parâmetros normais da função (parâmetros dentro dos
Q8: ? parênteses). A função não pode usar seletores e, para programas em
Q9: ? C++, não pode usar o tipo string.
Q10: ?
Q11: ?
Q12: ? Sugestões: a) Use um vetor de nomes (ponteiro para ponteiro para
Q13: ? caractere). b) Faça alocação dinâmica na função para o resultado e
Q14: ?
Q15: ?
deixe que a memória seja liberada fora da função.
Total: 40
Entradas:

1. Inteiro referente ao mês desejado.

Saídas:

1. O mês (a letra inicial deve ser maiúscula e as demais devem


ser minúsculas).

Exemplo de Entrada:

Exemplo de Saída:

Agosto

Peso: 1

Última tentativa realizada em: 16/01/2018 09:56:06

Tentativas: 4 de 6

Nota (0 a 100): 68.6

Status ou Justificativa de Nota: O programa usa memória demais,


verifique seus vetores. O programa pode acessar posições indevidas da
memória.

Ver Código da Última Tentativa

https://dredd.dcc.ufla.br/testTrials.php#p703 5/16
29/01/2018 Dredd - Juiz Online

Nova Resposta:
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta

Minutos
Restantes:
6541

Usuário:
Leonardo Questão 6: Ponteiros - Concatenação de dois vetores
Henrique de Braz

Notas:
Q1: 100
Q2: 100
Escreva um programa que leia duas cadeias de caracteres e concatene
Q3: 95 a segunda cadeia ao final da primeira. As duas cadeias de entrada
Q4: 100 devem ser declaradas como vetores de char com tamanhos máximos
Q5: 68.6 fixos, limitadas a 100 caracteres cada. A cadeia resultante deve ser
Q6: 39.5
Q7: 100
declarada como um ponteiro para o tipo de dado char que aponta para
Q8: ? uma variável dinâmica.
Q9: ?
Q10: ?
Q11: ?
Calcule a quantidade de memória necessária para armazenar o
Q12: ? resultado da concatenação antes de alocar memória para o resultado.
Q13: ? Obs: Em C++, a função strlen da biblioteca cstring pode ser usada
Q14: ? para calcular o número de caracteres úteis de um vetor de char.
Q15: ?
Total: 40
Colocar também um espaço entre as duas strings.

Entradas:

1. Elementos do primeiro vetor


2. Elementos do segundo vetor

Saídas:

Vetor resultante da concatenação do primeiro vetor com o


segundo

Exemplo de Entrada:

q w e r t y u i o p
m n b v c x z

Exemplo de Saída:

q w e r t y u i o p m n b v c x z

Peso: 1

Última tentativa realizada em: 31/12/2017 03:08:35

Tentativas: 1 de 6

Nota (0 a 100): 39.5

Status ou Justificativa de Nota: A quantidade de dados escritos pelo


programa é diferente da quantidade de dados esperados.

https://dredd.dcc.ufla.br/testTrials.php#p703 6/16
29/01/2018 Dredd - Juiz Online

Ver Código da Última Tentativa

Nova Resposta:
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta


Minutos
Restantes:
6541

Usuário:
Leonardo
Henrique de Braz

Notas: Questão 7: Ponteiros – Alocação Dinâmica e Subprograma


Q1: 100
Q2: 100
Q3: 95
Q4: 100 Faça um subprograma (do tipo procedimento) para preencher
Q5: 68.6
Q6: 39.5
automaticamente um vetor de números em ponto flutuante, nomeie o
Q7: 100 subprograma como obterVetor. Para preencher o vetor seu
Q8: ? subprograma deverá satisfazer as seguintes restrições:
Q9: ?
Q10: ?
Q11: ?
1. O valor a ser armazenado em uma posição i qualquer do
Q12: ? vetor deverá ser obtido a partir da expressão: (2 * i! + i) / (i*i +
Q13: ? 1.75). Note que i representa os índices dos subscritos
Q14: ? (posições) do vetor.
Q15: ?
Total: 40
2. O subprograma de preenchimento do vetor deverá possuir
apenas dois parâmetros de entrada. O primeiro deles deverá
ser um tipo de dado ponteiro para números em ponto
flutuante e o outro deverá ser um inteiro indicando o tamanho
do vetor.
3. O vetor que armazenará os dados deverá ser alocado
dinamicamente.
4. A alocação dinâmica deverá ser realizada fora do
subprograma obterVetor.

Faça um subprograma principal para testar o procedimento obterVetor,


para isso seu programa deverá ler um inteiro N, alocar dinamicamente
o vetor, chamar o subprograma obterVetor e preencher o vetor. Em
seguida, seu programa deverá ler um segundo número inteiro M e
exibir no dispositivo de saída padrão todos os valores armazenados no
vetor a partir da posição M (inclusive). Note que todas as operações de
entrada e saída de dados devem ser realizadas no subprograma
principal. Assuma que M sempre será menor do que N.

Entradas:

1. Inteiro N.
2. Inteiro M.

Saídas:

1. Sequência de (N-M) valores em ponto flutuante. Indicando os


valores armazenados no vetor.

Exemplo de Entrada:

5
0

Exemplo de Saída:

https://dredd.dcc.ufla.br/testTrials.php#p703 7/16
29/01/2018 Dredd - Juiz Online

1.14286
1.09091
1.04348
1.39535
2.92958

Exemplo de Entrada:
Minutos
Restantes:
6541 5
3
Usuário:
Leonardo
Henrique de Braz Exemplo de Saída:
Notas:
Q1: 100
Q2: 100
1.39535
Q3: 95 2.92958
Q4: 100
Q5: 68.6
Q6: 39.5
Q7: 100
Q8: ?
Peso: 1
Q9: ?
Q10: ? Última tentativa realizada em: 16/01/2018 10:11:42
Q11: ?
Q12: ?
Q13: ? Tentativas: 1 de 6
Q14: ?
Q15: ?
Total: 40 Nota (0 a 100): 100

Status ou Justificativa de Nota: Nenhum erro encontrado.

Ver Código da Última Tentativa

Nova Resposta:
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta

Questão 8: Ponteiros - Pontuação das medalhas

O Comitê Olímpico Internacional (COI) resolveu criar uma tabela de


pontuação das Olimpíadas para ser usada no lugar do Quadro de
Medalhas. A ideia é que cada tipo de medalha (ouro, prata e bronze)
tenha uma pontuação diferente. Assim, a pontuação de um time seria
baseada na quantidade de medalhas recebidas e nessa pontuação.

O COI precisa definir qual será a pontuação de cada tipo de medalha e,


para testar isso, pediu a você para fazer um programa que receba
quantos pontos valem cada tipo de medalha e a quantidade de
medalhas de um determinado país. Seu programa deverá então exibir a
pontuação daquele país nessa tabela de pontuação proposta.

Para isso seu programa deve:

https://dredd.dcc.ufla.br/testTrials.php#p703 8/16
29/01/2018 Dredd - Juiz Online

1. Guardar os pontos de cada tipo de medalha em memória


alocada dinamicamente.
2. Criar um registro para guardar as quantidades de medalhas
do país.
3. Usar alocação dinâmica para guardar o registro acima.

Entradas:

Minutos 1. Três números inteiros representando quantos pontos valem


Restantes: os tipos de medalha (ouro, prata e bronze, nessa ordem).
6541 2. Três números inteiros representando a quantidade de
Usuário:
medalhas recebida por um determinado país (de ouro, de
Leonardo prata e de bronze, nessa ordem).
Henrique de Braz
Saídas:
Notas:
Q1: 100
Q2: 100 1. A pontuação do país na tabela proposta pelo COI.
Q3: 95
Q4: 100
Q5: 68.6
Exemplo de Entrada:
Q6: 39.5
Q7: 100
Q8: ? 10 5 1
Q9: ? 2 2 2
Q10: ?
Q11: ?
Q12: ? Exemplo de Saída:
Q13: ?
Q14: ?
Q15: ? 32
Total: 40

Peso: 1
Nova Resposta:
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta

Questão 9: Ponteiros - Diferença de tempo nos 100m rasos

Houve uma pane no sistema de contagem de tempo das Olimpíadas, e


Comitê Olímpico Internacional (COI), pediu para você fazer um
programa que, dado o tempo de cada atleta em uma prova da corrida
de 100m rasos, calcule a diferença de tempo de todos os competidores
para o primeiro colocado.

Seu programa deverá usar um registro para guardar o tempo (ponto


flutuante) dos oito atletas da prova e os dados passados pelo usuário
devem ser guardados em um registro alocado dinamicamente. Seu
programa deverá então encontrar o primeiro colocado, e calcular a
diferença de tempo dos demais atletas para o tempo dele (essas
diferenças de tempo também devem ser guardadas em memória
alocada dinamicamente). Ao exibir as diferenças de tempo, no caso
do atleta que ganhou a prova (cuja diferença seria zero), escreva o
tempo dele na prova.

https://dredd.dcc.ufla.br/testTrials.php#p703 9/16
29/01/2018 Dredd - Juiz Online

Entradas:

1. O tempo de oito atletas em uma prova de corrida dos 100m


rasos.

Saídas:

1. A diferença de tempo do primeiro colocado para cada um dos


Minutos demais oito atletas (na ordem em que os dados foram
Restantes: recebidos). Obs: no lugar do primeiro colocado deve ser
6541
exibido o tempo dele na prova.
Usuário:
Leonardo Exemplo de Entrada:
Henrique de Braz

Notas: 10.5
Q1: 100
Q2: 100 10.2
Q3: 95 10.6
Q4: 100 10.8
Q5: 68.6
Q6: 39.5
10.1
Q7: 100 10.7
Q8: ? 11
Q9: ?
Q10: ?
11.1
Q11: ?
Q12: ?
Q13: ? Exemplo de Saída:
Q14: ?
Q15: ?
Total: 40 0.4
0.1
0.5
0.7
10.1
0.6
0.9
1

Peso: 1
Nova Resposta:
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta

Questão 10: Ponteiros - Mega Sena

Declare um registro para armazenar um resultado de um sorteio da


mega sena. Faça um programa que receba do usuário uma quantidade
de sorteios e as dezenas sorteadas, armazenando-as em um vetor
alocado dinamicamente. Faça então um subprograma que receba esse
vetor e retorne um ponteiro para o registro que tenha a maior soma de
dezenas sorteadas. Por fim, exiba os dados do registro retornado.

Entrada:
https://dredd.dcc.ufla.br/testTrials.php#p703 10/16
29/01/2018 Dredd - Juiz Online

1. Um número indicando a quantidade de sorteios.


2. As dezenas sorteadas em cada sorteio (vetor alocado
dinamicamente).

Saída:

1. As dezenas do registro que tem a maior soma de dezenas


sorteadas.
Minutos
Restantes: Exemplo de entrada:
6541

Usuário: 3
Leonardo
Henrique de Braz 41 44 48 50 54 57
02 17 22 24 48 51
Notas: 14 34 46 47 56 57
Q1: 100
Q2: 100
Q3: 95
Q4: 100
Exemplo de saída:
Q5: 68.6
Q6: 39.5
Q7: 100
41 44 48 50 54 57
Q8: ?
Q9: ?
Q10: ?
Q11: ? Peso: 1
Q12: ?
Q13: ? Nova Resposta:
Q14: ?
Q15: ?
Total: 40
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta

Questão 11: Ponteiros - Caça Palavras em Matriz

Desenvolva um programa que receba uma matriz nxn (n fornecido pelo


usuário) de caracteres (um caractere em cada posição da matriz). O
usuário digitará m palavras (m informado na entrada). O programa deve
procurar a ocorrência de cada palavra na matriz, imprimindo as
coordenadas da primeira letra ou -1 -1 se a palavra não existir. A
procura deve ser feita na horizontal (da esquerda para direita) e na
vertical (de cima para baixo).

OBS: Letras maiúsculas e minúsculas são diferenciadas. A matriz deve


ser alocada dinamicamente. A função strlen retorna o tamanho de
uma string. Não é necessário usar os mesmos nomes do enunciado.

Entradas:

1. Tamanho do lado da matriz (n)


2. Matriz de caracteres (nxn)
3. Número de palavras (m)
4. Palavras sem espaços, uma em cada linha

Saídas:

https://dredd.dcc.ufla.br/testTrials.php#p703 11/16
29/01/2018 Dredd - Juiz Online

1. Posição da letra inicial de cada palavra na matriz, na ordem


em que as palavras foram lidas.

Exemplo de Entrada:

3
A B C
D E F
Minutos
Restantes:
G H I
6541 2
BE
Usuário:
Leonardo
FI
Henrique de Braz

Notas: Exemplo de Saída:


Q1: 100
Q2: 100
Q3: 95 0 1
Q4: 100 1 2
Q5: 68.6
Q6: 39.5
Q7: 100
Q8: ?
Q9: ? Peso: 1
Q10: ?
Q11: ? Nova Resposta:
Q12: ?
Q13: ? Selecione o arquivo com o código fonte do programa que resolve o
Q14: ? problema para enviá-lo.
Q15: ?
Total: 40
Escolher arquivo Nenhum arquivo selecionado Enviar Resposta

Questão 12: Ponteiros - Provas de Uma Escola

Um escola deseja automatizar o processo de cálculo de notas da


seguinte maneira. Um registro para representar um aluno deve ser
criado com o número de matrícula e notas de 2 provas.

Uma matriz nxn será alocada dinamicamente e cada posição contará


com um ponteiro para o tipo aluno. Os dados de todos os alunos (nxn)
devem ser cadastrados, e para cada aluno será criada uma estrutura
com alocação dinâmica e o respectivo ponteiro da matriz será
atualizado para apontar para essa estrutura.

Após isso, a matriz terá cada coluna ordenada pela nota final do aluno
(crescente), que é calculada pela média simples das duas notas.

Entradas:

1. Tamanho dos lados da matriz n


2. Sequencia de dados dos nxn alunos

Saídas:

1. No de Matrícula de cada aluno, na ordem que aparece na


matriz.
2.

https://dredd.dcc.ufla.br/testTrials.php#p703 12/16
29/01/2018 Dredd - Juiz Online

Exemplo de Entrada:

2
1 100 90 2 70 80
3 60 60 4 100 100

Exemplo de Saída:
Minutos
Restantes:
6541 3 2
1 4
Usuário:
Leonardo
Henrique de Braz

Notas: Peso: 1
Q1: 100
Q2: 100 Nova Resposta:
Q3: 95
Q4: 100 Selecione o arquivo com o código fonte do programa que resolve o
Q5: 68.6
Q6: 39.5
problema para enviá-lo.
Q7: 100
Q8: ?
Escolher arquivo Nenhum arquivo selecionado Enviar Resposta
Q9: ?
Q10: ?
Q11: ?
Q12: ?
Q13: ?
Q14: ?
Q15: ?
Total: 40
Questão 13: Ponteiros - Copiar String para Vetor de
Caracteres

Escreva um programa que recebe duas strings e copia o resultado da


concatenação dessas duas strings em um vetor de caracteres, alocado
dinâmicamente, utilizando ponteiros e new. Não se esqueça de utilizar
getline(cin,nome_da_string) para receber cada uma das strings.

Exemplo de Entrada:

O Boi Bumbá e a Vaca Estrela


Foram para Pira Pora Nossa!

Exemplo de Saída:

O Boi Bumbá e a Vaca EstrelaForam para Pira Pora Nossa!

Peso: 1
Nova Resposta:
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta

https://dredd.dcc.ufla.br/testTrials.php#p703 13/16
29/01/2018 Dredd - Juiz Online

Questão 14: Ponteiros - Vetor dinâmico (modularização)

Faça um programa que guarda números num vetor dinâmico. Não se


sabe quantos números deverão ser armazenados até que se saiba
quais são os números.

Minutos
Restantes:
A estratégia de alocação de memória deve ser a seguinte:
6541
o vetor é criado inicialmente com capacidade 5,
Usuário: conforme é feito o armazenamento de números no vetor,
Leonardo
Henrique de Braz
novos espaços de memória vão sendo alocados, sempre com
5 elementos a mais do que antes. Ou seja, um novo vetor
Notas: com capacidade anterior mais 5 será alocado; os elementos
Q1: 100 devem ser copiados para o novo vetor e o antigo deve ser
Q2: 100 desalocado. Use subprogramas.
Q3: 95
Q4: 100
Q5: 68.6 O programa deverá ler números inteiros positivos da entrada padrão. O
Q6: 39.5 último número na entrada de dados será um número não positivo,
Q7: 100
Q8: ?
indicando o fim dos números. Considera-se que o zero não é positivo,
Q9: ? conforme pode ser visto no exemplo de entrada.
Q10: ?
Q11: ?
Q12: ?
Ao final da entrada de dados, o programa deverá:
Q13: ?
Q14: ? 1. Escrever todos os números (não negativos) armazenados.
Q15: ? 2. Escrever qual a capacidade atual do vetor.
Total: 40
3. Escrever o número de transformações (realocações na
memória) necessárias.

Exemplo de Entrada:

10 18 15 71 42 41 20 18 35 14 13 0

Exemplo de Saída:

10 18 15 71 42 41 20 18 35 14 13
15
2

Peso: 1
Nova Resposta:
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta

Questão 15: Ponteiros - Batalha Naval 1 (matriz,


subprogramas, arquivo, alocação)

https://dredd.dcc.ufla.br/testTrials.php#p703 14/16
29/01/2018 Dredd - Juiz Online

Leia de um arquivo de nome "BatalhaNaval.txt", duas matrizes de


tamanho NxN a serem alocadas dinamicamente, sendo que primeira
matriz representa a localização dos navios no tabuleiro e a segunda
matriz representa a posição de onde os tiros atingiram na primeira
matriz.

Na primeira matriz, k representa uma parte do k-ésimo navio, 0 partes


Minutos no mar.
Restantes:
6541
Na segunda matriz, 1 representa a posição do tiro (correspondente a
Usuário:
Leonardo
posição na primeira matriz), 0 posição sem tiro.
Henrique de Braz
Os navios sempre terão tamanho maior que uma posição da matriz, e
Notas:
Q1: 100
estarão sempre totalmente na vertical ou horizontal.
Q2: 100
Q3: 95 O programa deverá retornar o número total de navios completamente
Q4: 100
Q5: 68.6
afundados pelos tiros. OBS: Sub-rotinas devem ser utilizadas.
Q6: 39.5
Q7: 100 Entradas:
Q8: ?
Q9: ?
Q10: ? 1. Tamanho da matriz N (inteiro).
Q11: ? 2. Valores da primeira matriz NxN (inteiros).
Q12: ?
Q13: ?
3. Valores da segunda matriz NxN (inteiros).
Q14: ?
Q15: ? Saídas:
Total: 40
1. Número total de navios completamente afundados (inteiro).

Exemplo de Entrada:

5
0 1 1 1 0
2 0 0 0 0
2 0 0 0 0
2 0 0 0 0
2 3 3 0 0
0 1 1 1 1
1 0 0 0 0
1 0 0 0 0
1 0 0 0 0
1 1 0 0 0

Exemplo de Saída:

Peso: 1
Nova Resposta:
Selecione o arquivo com o código fonte do programa que resolve o
problema para enviá-lo.

Escolher arquivo Nenhum arquivo selecionado Enviar Resposta

https://dredd.dcc.ufla.br/testTrials.php#p703 15/16
29/01/2018 Dredd - Juiz Online

Desenvolvido por Bruno


Schneider a partir do programa
original (Algod) de Renato R.
R. de Oliveira.

Minutos
Restantes:
6541

Usuário:
Leonardo
Henrique de Braz

Notas:
Q1: 100
Q2: 100
Q3: 95
Q4: 100
Q5: 68.6
Q6: 39.5
Q7: 100
Q8: ?
Q9: ?
Q10: ?
Q11: ?
Q12: ?
Q13: ?
Q14: ?
Q15: ?
Total: 40

https://dredd.dcc.ufla.br/testTrials.php#p703 16/16

Você também pode gostar