Ir ao conteúdo

Posts recomendados

Postado

Dado um número n inteiro e positivo, dizemos que n é perfeito se n for igual à soma de seus divisores
positivos diferentes de n. Construa um programa que leia um número inteiro n, apresenta a soma dos
divisores de n e verifica se o número informado é perfeito ou não.
Escreva uma função somaDivisores que receba como parâmetro um número inteiro e retorne a soma
dos divisores desse número excluindo o próprio número como divisor de si mesmo. Seu programa deve
chamar a função somaDivisores para resolver o problema.
Entrada
O programa deve ler um número inteiro n.
Saída
O programa deve apresentar uma linha contendo o texto: "n = d1 + d2 + d3 + ... + dk = x (MENSAGEM)",
onde n é o número lido, di são os divisores de n em ordem crescente, x é a soma dos divisores e
MENSAGEM é a mensagem "NUMERO PERFEITO"ou "NUMERO NAO E PERFEITO".
Observações
Suponha que o usuário sempre fornecerá um número maior que 1.
Exemplo
Entrada
6
Saída
6 = 1 + 2 + 3 = 6 (NUMERO PERFEITO)
Entrada
12
Saída
12 = 1 + 2 + 3 + 4 + 6 = 16 (NUMERO NAO E PERFEITO)

 

Codigo por enquanto:

#include<stdio.h>
int somadivisores (int numero) {
 
}

main () {
int numero;
    scanf("%d",&numero);
    int i;
    int divisor=1;
    int resto;
    int somad;
    for (i=0;i<numero;i++) {      
        resto = numero%divisor;
        somad = somad+divisor;
        if ( resto == 0 ){
             if (somad == numero) {
                        
            }
                }
    divisor++;
}
}

 

Ainda não comecei a fazer a função porque parei na lógica (essa saída dos divisores, como vou colocar?), queria ajuda pra finalizar minha lógica.

Obs: Faço introdução a programação em C, ou seja, não vou entender comandos avançados.

 

  • Membro VIP
Postado

Olá @fernandobrito.

 

13 horas atrás, fernandobrito disse:

dizemos que n é perfeito se n for igual à soma de seus divisores positivos diferentes de n

Então, para ter "a soma dos divisores" é necessário antes "ter os divisores"... ou seja, sugiro que crie um programa que apenas receba um valor N e retorna os seus divisores. Não se preocupe com a soma por enquanto. O objetivo é apenas ter acesso aos divisores.

 

Daí, depois implementa o restante do código.

 

Qualquer coisa é só postar.

 

 

No aguardo.

 

 

  • Obrigado 1
Postado

Como o amigo a cima disse. Primeiro temos que achar os divisores do numero diferentes do proprio numero. Depois que conseguir uma função para retornar estes valores é só somar eles e ver se é igual ao numero inteiro N informado.

PS: Tente trabalhar um pouco mais na sua identação.

 

PS²: Caso a dúvida esteja na lógica do programa e não na programação em si avise que eu tento esclarecer melhor qual a lógica do problema.

  • Curtir 1
  • Obrigado 1

Crie uma conta ou entre para comentar

Você precisa ser um usuário para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...

GRÁTIS: ebook Redes Wi-Fi – 2ª Edição

EBOOK GRÁTIS!

CLIQUE AQUI E BAIXE AGORA MESMO!