Ir ao conteúdo
  • Cadastre-se

Java Fatorial com número exponencial


Posts recomendados

Estou tentando fazer um exercício no qual tem que se receber um valor n e fazer o fatorial exponecial dele tipo: n elevado a n-1, elevado a n-2 assim por diante até o n elevado chegar no valor de n. Até agora eu fiz isso, sei que deve ter algum erro de lógica mas não consigo achar alguém poderia me ajudar?Segue abaixo o código já feito. Desde já agradeço!


 

import java.util.*;

public class Lista7Ex38
{
    private Scanner input;
    int numero;
    int fatorial = 0;
    double expo = 0;
    int i = 1;

    public void fatorial()
    {
        input = new Scanner(System.in);
        System.out.println("Digite um número:");
        numero = input.nextInt();

        while (i <= numero)
        {

            fatorial = numero - i;
            expo = Math.pow(numero, fatorial);
            i++;
        }

        System.out.println("O resultado é =" + expo);
    }

    public static void main(String[] args)
    {

        Lista7Ex38 l = new Lista7Ex38();
        l.fatorial();

    }
}

 

Link para o comentário
Compartilhar em outros sites

 Fac¸a uma func¸ao n ão-recursiva que receba um numero inteiro positivo n e retorne o fa-
torial exponencial desse numero. Um fatorial exponencial é um inteiro positivo n elevado
a potência de  n − 1, que por sua vez é elevado  a potência de  n − 2 e assim em diante.

 

 

Esse é o exercício que estou tentando fazer, se puder me ajudar agradeceria muito . 
@Leonardo0308

Link para o comentário
Compartilhar em outros sites

Olha se eu entendi bem seria algo assim

 

n=3

resp = (3 ^ 2) + (3 ^ 1) + (3 ^ 0)

resp = 9 + 3 + 1

resp = 13

 

Se essa for a logica matemática correta, o código ficaria algo assim

while (i <= numero)
        {
            fatorial = numero - i;
            expo = expo + Math.pow(numero, fatorial);
            i++;
        }

Para corresponder a formula.

 

Espero ter ajudado :D

 

  • Obrigado 1
Link para o comentário
Compartilhar em outros sites

1 hora atrás, Leonardo0308 disse:

Olha se eu entendi bem seria algo assim

 

n=3

resp = (3 ^ 2) + (3 ^ 1) + (3 ^ 0)

resp = 9 + 3 + 1

resp = 13

 

Se essa for a logica matemática correta, o código ficaria algo assim


while (i <= numero)
        {
            fatorial = numero - i;
            expo = expo + Math.pow(numero, fatorial);
            i++;
        }

Para corresponder a formula.

 

Espero ter ajudado :D

 

Acho que é isso mesmo, muito obrigado cara. A minha lógica estava quase certa só faltou eu somar o expo pelos números elevado! Obrigadão!!!!!! 

  • Curtir 1
Link para o comentário
Compartilhar em outros sites

@Leonardo0308Na real a resposta não era aquela não man. Mas agora sim eu consegui, depois de ficar praticamente o dia todo pensando ai está o resultado e está dando certinho. No que você fez o valores que eram elevados se somavam, mas não era para somar era para se elevar novamente ao próximo valor da subtração do número N .

a fórmula seria :

n=3

resp=(3^2)^(3^1)

resp=729

Ai ficou assim man. 

expo = Math.pow(numero, numero);

		for (i = 1; i < numero; i++)
		{

			resultado = Math.pow(expo, fatorial);
			fatorial = numero - i;

		}

Mas de qualquer forma muito obrigado pela tentativa! Agradeço por ter gastado o seu tempo tentando me ajudar :D

  • Curtir 1
Link para o comentário
Compartilhar em outros sites

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...