Logo Passei Direto
Buscar

Algoritmos e Complexidade

User badge image
Italo Mello

em

Ferramentas de estudo

Questões resolvidas

Material
páginas com resultados encontrados.
páginas com resultados encontrados.
left-side-bubbles-backgroundright-side-bubbles-background

Crie sua conta grátis para liberar esse material. 🤩

Já tem uma conta?

Ao continuar, você aceita os Termos de Uso e Política de Privacidade

left-side-bubbles-backgroundright-side-bubbles-background

Crie sua conta grátis para liberar esse material. 🤩

Já tem uma conta?

Ao continuar, você aceita os Termos de Uso e Política de Privacidade

left-side-bubbles-backgroundright-side-bubbles-background

Crie sua conta grátis para liberar esse material. 🤩

Já tem uma conta?

Ao continuar, você aceita os Termos de Uso e Política de Privacidade

left-side-bubbles-backgroundright-side-bubbles-background

Crie sua conta grátis para liberar esse material. 🤩

Já tem uma conta?

Ao continuar, você aceita os Termos de Uso e Política de Privacidade

left-side-bubbles-backgroundright-side-bubbles-background

Crie sua conta grátis para liberar esse material. 🤩

Já tem uma conta?

Ao continuar, você aceita os Termos de Uso e Política de Privacidade

left-side-bubbles-backgroundright-side-bubbles-background

Crie sua conta grátis para liberar esse material. 🤩

Já tem uma conta?

Ao continuar, você aceita os Termos de Uso e Política de Privacidade

Questões resolvidas

Prévia do material em texto

Algoritmos
O que e um algoritmo?
a) Um tipo de hardware utilizado em computadores
b) Uma sequencia finita de instrucoes que resolve um problema
c) Um programa que so roda em computadores quanticos
d) Uma linguagem de programacao especifica
Resposta explicativa: Um algoritmo e uma sequencia ordenada de passos ou instrucoes que,
quando executados corretamente, resolvem um problema especifico ou realizam uma tarefa. Ele
nao depende de linguagem de programacao e pode ser descrito de forma abstrata.
Qual das alternativas abaixo caracteriza um algoritmo correto?
a) Sempre termina apos um numero finito de passos
b) Pode executar indefinidamente sem produzir resultado
c) Depende de decisoes humanas durante a execucao
d) Funciona apenas com dados numericos
Resposta explicativa: Um algoritmo correto deve terminar em um numero finito de passos e produzir
um resultado esperado. Se puder rodar indefinidamente sem finalizar, ele nao e considerado um
algoritmo valido.
Qual e a diferenca entre algoritmo e programa de computador?
a) Programa e abstrato, algoritmo e implementado em codigo
b) Algoritmo e abstrato, programa e a implementacao pratica do algoritmo
c) Nao ha diferenca entre os dois conceitos
d) Algoritmo depende do sistema operacional, programa nao
Resposta explicativa: O algoritmo descreve a logica de resolucao de um problema de forma
abstrata, enquanto o programa e a implementacao desse algoritmo em uma linguagem de
programacao especifica que o computador consegue executar.
Qual e a importancia da complexidade de um algoritmo?
a) Determina a quantidade de memoria necessaria
b) Indica quanto tempo o algoritmo leva para resolver problemas de diferentes tamanhos
c) Define a linguagem de programacao ideal para implementacao
d) Permite que o algoritmo seja executado em qualquer hardware
Resposta explicativa: A complexidade de um algoritmo mede o consumo de recursos, geralmente
tempo ou espaco de memoria, a medida que o tamanho da entrada aumenta. Ela ajuda a comparar
algoritmos e escolher o mais eficiente para um problema.
O que e um algoritmo de ordenacao?
a) Um algoritmo que organiza dados em uma sequencia especifica
b) Um algoritmo que calcula operacoes matematicas complexas
c) Um algoritmo que busca dados em uma estrutura de arquivos
d) Um algoritmo que converte dados entre diferentes formatos
Resposta explicativa: Um algoritmo de ordenacao organiza os elementos de uma lista ou colecao
em uma ordem definida, como crescente ou decrescente. Exemplos incluem Bubble Sort, Merge
Sort e Quick Sort.
Qual e a principal diferenca entre algoritmos deterministicos e nao deterministicos?
a) Algoritmos deterministicos sempre produzem o mesmo resultado para a mesma entrada,
enquanto nao deterministicos podem produzir diferentes resultados
b) Algoritmos deterministicos usam apenas numeros inteiros
c) Algoritmos nao deterministicos nao podem ser implementados em computadores
d) Nao ha diferenca pratica entre eles
Resposta explicativa: Algoritmos deterministicos produzem sempre o mesmo resultado para a
mesma entrada, enquanto algoritmos nao deterministicos podem produzir resultados diferentes em
execucoes diferentes, muitas vezes utilizando elementos de aleatoriedade ou multiplos caminhos
de execucao.
Em analise de algoritmos, o que significa notacao Big O?
a) Indica a quantidade de dados que o algoritmo pode processar
b) Representa o pior caso de crescimento da complexidade do algoritmo
c) Mostra a precisao do algoritmo em resultados matematicos
d) E usada para determinar a linguagem de programacao ideal
Resposta explicativa: A notacao Big O descreve o crescimento da complexidade do algoritmo no
pior caso em funcao do tamanho da entrada. Ela permite comparar algoritmos sem depender do
hardware ou da implementacao especifica.
Qual algoritmo e considerado mais eficiente para busca em listas ordenadas?
a) Busca linear
b) Busca binaria
c) Busca em profundidade
d) Busca por hashing
Resposta explicativa: A busca binaria e mais eficiente para listas ordenadas, pois reduz o espaco
de busca pela metade a cada comparacao, resultando em complexidade
O(logn), enquanto a busca linear verifica elemento por elemento, com complexidade
O(n).
Qual e o criterio para classificar um algoritmo como recursivo?
a) Quando ele usa loops aninhados
b) Quando ele chama a si mesmo diretamente ou indiretamente
c) Quando utiliza memoria dinamica
d) Quando nao depende de entrada do usuario
Resposta explicativa: Um algoritmo recursivo se caracteriza por chamar a si mesmo para resolver
subproblemas menores ate atingir um caso base, permitindo resolver problemas complexos de
forma mais concisa.
Qual e a principal vantagem de algoritmos recursivos?
a) Maior velocidade em todos os casos
b) Codigo mais conciso e intuitivo para problemas divididos em subproblemas
c) Reduz a memoria utilizada em comparacao com loops
d) Nao precisa de casos base
Resposta explicativa: A recursao permite escrever algoritmos de maneira mais clara e intuitiva,
especialmente para problemas que podem ser divididos em subproblemas, como arvores, grafos e
sequencias de Fibonacci, embora nem sempre seja a abordagem mais eficiente em termos de
memoria.
O que e um algoritmo guloso?
a) Um algoritmo que escolhe sempre a melhor opcao local
b) Um algoritmo que considera todas as combinacoes possiveis
c) Um algoritmo que depende exclusivamente de programacao dinamica
d) Um algoritmo que apenas ordena elementos
Resposta explicativa: Um algoritmo guloso toma decisoes baseadas na melhor escolha disponivel
no momento, assumindo que essa escolha local levara a uma solucao otima global, como no
problema da mochila fracionaria ou na arvore geradora minima.
Qual e a diferenca entre algoritmo exato e heuristico?
a) Algoritmos exatos fornecem solucoes garantidas, heuristicos fornecem solucoes aproximadas
b) Algoritmos heuristicos sao sempre mais lentos
c) Algoritmos exatos nao funcionam em computadores
d) Nao ha diferenca entre eles
Resposta explicativa: Algoritmos exatos garantem a solucao otima, mesmo que levem mais tempo,
enquanto heuristicos oferecem solucoes proximas do otimo rapidamente, sendo uteis para
problemas NP-dificeis ou muito grandes.
Qual e a funcao de um algoritmo de busca em grafos?
a) Determinar o caminho ou a relacao entre vertices de um grafo
b) Ordenar os vertices por grau
c) Converter grafos em arvores
d) Reduzir a complexidade do grafo
Resposta explicativa: Algoritmos de busca, como Busca em Profundidade (DFS) e Busca em
Largura (BFS), exploram os vertices e arestas do grafo para encontrar caminhos, componentes
conectados ou ciclos, desempenhando papel central em analise de redes.
Qual e a diferenca entre BFS e DFS?
a) BFS explora vertices em profundidade, DFS em largura
b) BFS explora vertices em largura, DFS em profundidade
c) BFS e DFS sao equivalentes em todos os casos
d) BFS e usado apenas em arvores, DFS apenas em grafos
Resposta explicativa: BFS (Busca em Largura) explora todos os vertices de um nivel antes de
avancar para o proximo, enquanto DFS (Busca em Profundidade) explora um caminho ate o fim
antes de retroceder, sendo util para diferentes tipos de analise em grafos.
Qual e a complexidade de um algoritmo de ordenacao Bubble Sort no pior caso?
a)
O(n)
b)
O(nlogn)
c)
O(n
2
)
d)
O(logn)
Resposta explicativa: No pior caso, Bubble Sort compara repetidamente pares de elementos
adjacentes e troca-os se necessario, resultando em complexidade
O(n
2
), tornando-o ineficiente para listas grandes.
Qual algoritmo de ordenacao possui complexidade
O(nlogn) na media e no pior caso?
a) Bubble Sort
b) Insertion Sort
c) Merge Sort
d) Selection Sort
Resposta explicativa: Merge Sort divide recursivamente a lista em metades, ordena cada metade e
depois combina os resultados, garantindo complexidade
O(nlogn) mesmo no pior caso, sendo eficiente para listas grandes.
O que significa que um algoritmo e polinomial?
a) Sua complexidade de tempoou espaco cresce como uma funcao polinomial do tamanho da
entrada
b) Ele e implementado usando apenas multiplicacoes e somas
c) Ele resolve apenas problemas matematicos
d) Ele sempre e mais rapido que algoritmos exponenciais
Resposta explicativa: Um algoritmo e considerado polinomial se seu tempo de execucao ou uso de
memoria cresce como uma funcao polinomial do tamanho da entrada, por exemplo,
O(n
2
) ou
O(n
3
), geralmente indicando eficiencia pratica.
Qual e a diferenca entre algoritmos de busca linear e binaria?
a) Busca linear exige lista ordenada, binaria nao
b) Busca linear percorre elemento por elemento, binaria divide a lista ordenada sucessivamente
c) Busca binaria e sempre mais lenta
d) Busca linear so funciona em listas pequenas
Resposta explicativa: Busca linear verifica cada elemento ate encontrar o alvo, sendo simples mas
lenta (
O(n)). Busca binaria funciona apenas em listas ordenadas, reduzindo o espaco de busca pela
metade a cada passo (
O(logn)), tornando-a mais eficiente.
Qual e o papel dos algoritmos em Inteligencia Artificial?
a) Determinar apenas o hardware necessario
b) Fornecer regras e processos para tomada de decisao e aprendizado
c) Substituir toda a programacao tradicional
d) Criar dados aleatorios sem finalidade
Resposta explicativa: Algoritmos em IA fornecem metodos sistematicos para que maquinas
aprendam, tomem decisoes ou resolvam problemas complexos, desde aprendizado de maquina ate
busca em jogos ou reconhecimento de padroes.
Qual e a diferenca entre algoritmo deterministico e probabilistico?
a) Algoritmo deterministico sempre produz o mesmo resultado para a mesma entrada, probabilistico
pode variar
b) Algoritmo probabilistico e mais rapido em todos os casos
c) Algoritmo deterministico e sempre recursivo
d) Nao existe diferenca entre eles
Resposta explicativa: Algoritmos deterministicos produzem sempre o mesmo resultado para uma
entrada, enquanto probabilisticos usam elementos de aleatoriedade, podendo gerar diferentes
resultados ou probabilidades de sucesso, uteis em otimizacao e problemas complexos.
Se voce quiser, posso continuar adicionando mais perguntas detalhadas sobre analise de
complexidade, algoritmos de grafos avancados, algoritmos de otimizacao e heuristicas, garantindo
que o documento ultrapasse confortavelmente 1000 palavras. Quer que eu continue?

Mais conteúdos dessa disciplina