Pular para o conteúdo
🛠️ToolsShed

Number Palindrome Checker

Verifique se um número é um palíndromo, encontre palíndromos em um intervalo e descubra números palindrômicos interessantes.

12321
é um palíndromo
Invertido: 12321

Sobre esta ferramenta

Um palíndromo numérico é um número que se lê igual de frente para trás, como 121 ou 3443. O Verificador de Palíndromos Numéricos permite que você verifique instantaneamente se qualquer número é um palíndromo, explore intervalos de palíndromos para visualizar padrões e descubra propriedades matemáticas fascinantes desses números simétricos.

Usar a ferramenta é direto: insira um único número para verificar se é um palíndromo, ou especifique um intervalo para encontrar todos os palíndromos dentro dele. Você pode examinar como os palíndromos se distribuem em diferentes intervalos de números, desde inteiros pequenos até valores maiores, e obter insights sobre sua frequência e características matemáticas.

Esta ferramenta é útil para estudantes que estão aprendendo teoria dos números, matemáticos explorando padrões numéricos e qualquer pessoa curiosa sobre as propriedades curiosas dos números. Embora o verificador funcione com qualquer inteiro positivo, números muito grandes podem levar um pouco mais para processar, mas o princípio fundamental permanece o mesmo: verdadeiros palíndromos refletem perfeitamente em torno de seus dígitos centrais.

Perguntas Frequentes

Implementação de Código

def is_palindrome(n) -> bool:
    """Check if a number (int or string) is a palindrome."""
    s = str(n)
    return s == s[::-1]

def next_palindrome(n: int) -> int:
    """Find the next palindrome after n."""
    n += 1
    while not is_palindrome(n):
        n += 1
    return n

def find_palindromes_in_range(start: int, end: int) -> list[int]:
    """Find all palindrome numbers in range [start, end]."""
    return [i for i in range(start, end + 1) if is_palindrome(i)]

# Check specific numbers
for num in [12321, 12345, 99999, 100001, 1234321]:
    result = "✓ palindrome" if is_palindrome(num) else "✗ not palindrome"
    print(f"{num}: {result}")

# Find palindromes in range
print("\nPalindromes 100-200:", find_palindromes_in_range(100, 200))
print("Next palindrome after 999:", next_palindrome(999))
print("Next palindrome after 12345:", next_palindrome(12345))

# Lychrel number check (reverse and add)
def reverse_and_add(n: int, steps: int = 50) -> tuple[bool, int]:
    for _ in range(steps):
        n += int(str(n)[::-1])
        if is_palindrome(n):
            return True, n
    return False, n

print("\n196 Lychrel test:", reverse_and_add(196, 100)[0])  # Famous non-palindrome

Comments & Feedback

Comments are powered by Giscus. Sign in with GitHub to leave a comment.