Planilha Web - Planilhas e Calculadoras online para estudantes e profissionais de Engenharia Civil, Engenharia Elétrica e Engenharia Mecânica.
E-Book 650 Dicas, Truques e Exercícios Resolvidos de Python - PDF com 1.200 páginas
Domine lógica de programação e a linguagem Python com o nosso E-Book 650 Dicas, Truques e Exercícios Exercícios de Python, para você estudar onde e quando quiser. Este e-book contém dicas, truques e exercícios resolvidos abrangendo os tópicos: Python básico, matemática e estatística, banco de dados, programação dinâmica, strings e caracteres, entrada e saída, estruturas condicionais, vetores e matrizes, funções, laços, recursividade, internet, arquivos e diretórios, programação orientada a objetos e muito mais.
Ver Conteúdo do E-book Apenas R$ 32,90
Você está aqui: Python ::: Desafios e Lista de Exercícios Resolvidos ::: Arrays e Matrix (Vetores e Matrizes)

Dado um vetor não ordenado de inteiros, encontre a maior sequência consecutiva em ordem crescente - Desafio de Programação Resolvido em Python

Quantidade de visualizações: 821 vezes
Pergunta/Tarefa:

Dado o vetor:

# vamos declarar um vetor de inteiros não ordenado
valores = [8, 3, 7, 1, 6, 2, 4, 9]
Escreva um programa Python que encontrará a maior sequência consecutiva, em ordem crescente. Sua saída deverá ser parecida com:

A maior sequencia consecutiva é: 4
Resposta/Solução:

Em todas as entrevistas que este desafio foi apresentado, o candidato foi informado de que poderia ordenar os valores antes de calcular a sequência consecutiva, o que torna o problema menos complicado. A solução apresentada a seguir usa esta abordagem:

# método principal  
def main():
  # vamos declarar um vetor de inteiros não ordenado
  valores = [8, 3, 7, 1, 6, 2, 4, 9]

  # o primeiro passo é ordenar o vetor em ordem crescente
  valores.sort()
  maiorSequencia = 1 # guarda a maior sequencia
  sequenciaAtual = 1 # guarda a sequencia atual
  
  # agora percorremos o vetor começando no segundo elemento
  # e indo até o último
  for i in range(1, len(valores)):
    # o elemento atual é diferente do elemento anterior?
    if(valores[i] != valores[i - 1]):
      # o elemento atual é maior que o seu sucessor?
      if(valores[i] == (valores[i - 1] + 1)):
        sequenciaAtual = sequenciaAtual + 1 # incrementa a sequencia atual
      else:
        # ajusta a maior sequencia
        maiorSequencia = max(maiorSequencia, sequenciaAtual)
        sequenciaAtual = 1 # sequencia atual volta a ser 1
    
  # mostra o resultado:
  print("A maior sequencia consecutiva é: {0}". format(
    max(maiorSequencia, sequenciaAtual)))

if __name__== "__main__":
  main()


Link para compartilhar na Internet ou com seus amigos:

Mais Desafios de Programação e Exercícios e Algoritmos Resolvidos de Python

Veja mais Dicas e truques de Python

Dicas e truques de outras linguagens

E-Books em PDF

E-Book 350 Exercícios Resolvidos de Java - PDF com 500 páginas
Domine lógica de programação e a linguagem Java com o nosso E-Book 350 Exercícios Exercícios de Java, para você estudar onde e quando quiser.

Este e-book contém exercícios resolvidos abrangendo os tópicos: Java básico, matemática e estatística, programação dinâmica, strings e caracteres, entrada e saída, estruturas condicionais, vetores e matrizes, funções, laços, recursividade, internet, arquivos e diretórios, programação orientada a objetos e muito mais.
Ver Conteúdo do E-book
E-Book 650 Dicas, Truques e Exercícios Resolvidos de Python - PDF com 1.200 páginas
Domine lógica de programação e a linguagem Python com o nosso E-Book 650 Dicas, Truques e Exercícios Exercícios de Python, para você estudar onde e quando quiser.

Este e-book contém dicas, truques e exercícios resolvidos abrangendo os tópicos: Python básico, matemática e estatística, banco de dados, programação dinâmica, strings e caracteres, entrada e saída, estruturas condicionais, vetores e matrizes, funções, laços, recursividade, internet, arquivos e diretórios, programação orientada a objetos e muito mais.
Ver Conteúdo do E-book

Linguagens Mais Populares

1º lugar: Java
2º lugar: Python
3º lugar: C#
4º lugar: PHP
5º lugar: C
6º lugar: Delphi
7º lugar: JavaScript
8º lugar: C++
9º lugar: VB.NET
10º lugar: Ruby



© 2025 Arquivo de Códigos - Todos os direitos reservados
Neste momento há 17 usuários muito felizes estudando em nosso site.