Ir ao conteúdo
  • Comunicados

    • Gabriel Torres

      Seja um moderador do Clube do Hardware!   12-02-2016

      Prezados membros do Clube do Hardware, Está aberto o processo de seleção de novos moderadores para diversos setores ou áreas do Clube do Hardware. Os requisitos são:   Pelo menos 500 posts e um ano de cadastro; Boa frequência de participação; Ser respeitoso, cordial e educado com os demais membros; Ter bom nível de português; Ter razoável conhecimento da área em que pretende atuar; Saber trabalhar em equipe (com os moderadores, coordenadores e administradores).   Os interessados deverão enviar uma mensagem privada para o usuário @Equipe Clube do Hardware com o título "Candidato a moderador". A mensagem deverá conter respostas às perguntas abaixo:   Qual o seu nome completo? Qual sua data de nascimento? Qual sua formação/profissão? Já atuou como moderador em algo outro fórum, se sim, qual? De forma sucinta, explique o porquê de querer ser moderador do fórum e conte-nos um pouco sobre você.   OBS: Não se trata de função remunerada. Todos que fazem parte do staff são voluntários.
    • DiF

      Poste seus códigos corretamente!   21-05-2016

      Prezados membros do Fórum do Clube do Hardware, O Fórum oferece um recurso chamado CODE, onde o ícone no painel do editor é  <>     O uso deste recurso é  imprescindível para uma melhor leitura, manter a organização, diferenciar de texto comum e principalmente evitar que os compiladores e IDEs acusem erro ao colar um código copiado daqui. Portanto convido-lhes para ler as instruções de como usar este recurso CODE neste tópico:  
Gabriel Gomes da Silva

Java Fatorial com número exponencial

Recommended Posts

Postado (editado)

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();

    }
}

 

Editado por Gabriel Gomes da Silva
Não tinha colocado o botão code onde eu coloquei meu código

Compartilhar este post


Link para o post
Compartilhar em outros sites

Bom dia @Gabriel Gomes da Silva

 

Eu acho que o problema ta aqui

 

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

 

mas eu não entendi direito a conta que você quer fazer.

 

Se poder me dar o exemplo matemático poderei lhe ajudar melhor.

 

Fico no aguardo.

Compartilhar este post


Link para o post
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

Compartilhar este post


Link para o post
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

Compartilhar este post


Link para o post
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

Compartilhar este post


Link para o post
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

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário






Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações 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

×