![]() |
|
||||
Planilha Web - Planilhas e Calculadoras online para estudantes e profissionais de Engenharia Civil, Engenharia Elétrica e Engenharia Mecânica. |
|||||
Você está aqui: Java ::: Desafios e Lista de Exercícios Resolvidos ::: Laços de Repetição |
Como testar se dois números são números amigos em Java - Escreva um programa Java que - Exercícios Resolvidos de JavaQuantidade de visualizações: 611 vezes |
|
Pergunta/Tarefa: Dois números inteiros positivos A e B são considerados números amigos se a soma dos divisores próprios de A for igual a B e a soma dos divisores próprios de B for igual a A. Divisores próprios de um número positivo N são todos os divisores inteiros positivos de N exceto o próprio N. Por exemplo, os divisores próprios de 6 são: 1, 2 e 3. Como exemplo de números amigos podemos citar 220 e 284. Os divisores próprios de 220 são 1, 2, 4, 5, 10, 11, 20, 22, 44, 55 e 110, resultando na soma 284. O número 284, por sua vez, possui os divisores próprios 1, 2, 4, 71 e 142, resultando na soma 220. Dessa forma, 220 e 284 são números amigos. Escreva um programa Java que leia dois números inteiros positivos e informe se eles são números amigos ou não. Sua saída deve ser parecida com: Informe o primeiro número: 220 Informe o segundo número: 284 Os dois números são amigos Informe o primeiro número: 158 Informe o segundo número: 932 Os números não são amigos. Informe o primeiro número: 1210 Informe o segundo número: 1184 Os dois números são amigos Veja a resolução comentada deste exercício usando Java: ----------------------------------------------------------------------
Se precisar de ajuda com o código abaixo, pode me chamar
no WhatsApp +55 (62) 98553-6711 (Osmar)
----------------------------------------------------------------------
package estudos;
import java.util.Scanner;
public class Estudos {
public static void main(String[] args) {
// variáveis usadas na resolução do problema
int n1, n2, soma = 0;
// para ler a entrada do usuário
Scanner entrada = new Scanner(System.in);
// vamos ler os dois números
System.out.print("Informe o primeiro número: ");
n1 = Integer.parseInt(entrada.nextLine());
System.out.print("Informe o segundo número: ");
n2 = Integer.parseInt(entrada.nextLine());
// vamos somar todos os divisores próprios do
// primeiro número
for(int i = 1; i < n1; i++){
if(n1 % i == 0){
soma = soma + i;
}
}
// se essa soma for igual ao valor de n2 nós já temos a
// primeira condição
if(soma == n2){
// zera a soma
soma = 0;
for(int i = 1; i < n2; i++){
if(n2 % i == 0){
soma = soma + i;
}
}
// esta soma é igual ao valor de n1?
if(soma == n1){
System.out.println("Os dois números são amigos\n");
}
else{
System.out.println("Os números não são amigos.\n");
}
}
else{
System.out.println("Os números não são amigos.\n");
}
}
}
Os números amigos eram conhecidos pelos Pitagóricos, que acreditavam que eles possuíam propriedades místicas. |
|
|
Mais Desafios de Programação e Exercícios e Algoritmos Resolvidos de Java |
Veja mais Dicas e truques de Java |
Dicas e truques de outras linguagens |
|
Python - Como obter o resto de uma divisão de inteiros em Python - O operador módulo % da linguagem Python |
E-Books em PDF |
||||
|
||||
|
||||
Linguagens Mais Populares |
||||
|
1º lugar: Java |






