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:  
Matheu Castelo

C# Crie uma função que receba um vetor de números reais e retorna o maior elemento

Recommended Posts

Postado (editado)

Não consigo fazer a entrada dos dados para o formulário, a questão é a seguinte: Crie uma função que receba um vetor de números reais e retorna o maior elemento do vetor.(não use funções prontas para tratar o vetor) Nome da função: maxVec.

Segue meu código abaixo:

 class Program
    {     
		static double[] maxVec(double[] v)
        {
            double calc = 0;
            
            for (int i = 0; i < v.Length; i++)
            {
                if (calc < v[i])
                {
                    calc = v[i];
                }
                else
                {

                }
            }
            return v;
        }
   		//Função que imprime o vetor
     static void imprimeVetor(int[] v)
        {
            for (int i = 0; i < v.Length; i++)
            {
                Console.Write(v[i] + " ");
            }
            if (v.Length < 1)
            {
                Console.Write("vazio");
            }
        }
			
			
            static void Main(string[] args)
        {
               Console.WriteLine("exe7");
            double[] r = { 2.0, 3.5, 10.0 };
            Console.WriteLine("esperado " + (10.0) + "\tretornado " + maxVec(r));
            double[] s = { 200.0, 3.5, 10.0 };
            Console.WriteLine("esperado " + (200.0) + "\tretornado " + maxVec(s));
            double[] t = { -2.0, -3.5, -10.0 };
            Console.WriteLine("esperado " + (-2.0) + "\tretornado " + maxVec(t));


            Console.ReadKey();
        }
    }

 

Exe7.PNG

Editado por Matheu Castelo

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Matheu Castelo  Olá. Tem alguns pontos na sua função q devem ser corrigidos.

O primeiro seria esse:

double calc = v[0];

Segundo, no seu if seria assim:

 

if (v[i] > calc)
{
    calc = v[i];
}

E aí retorne calc e não v como vinha fazendo

adicionado 9 minutos depois

na verdade seu if estava correto, só a ordem é alterada

adicionado 11 minutos depois

Só esse else dentro do for não é necessário

  • Obrigado 1

Compartilhar este post


Link para o post
Compartilhar em outros sites

@giu_d Olá, os resultados após as correções continuam os mesmos, ele não acusa nenhum erro, porém também não aparece o resultado.

Exe7.PNG

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Matheu Castelo  Fez a correção com relação ao retorno?

 

return calc;

 

adicionado 6 minutos depois
double calc = v[0];

for (int i = 0; i < 3; i++) // esse 3 é só p simplicar um pouco, caso o vetor seja de 3 posições
{
    if (v[i] > calc)
    {
        calc = v[i];
    }
}
return calc;

Passei a função de maneira bem resumida

adicionado 9 minutos depois

Dei uma olhada melhor no seu código. Você esta definindo sua função com o tipo de retorno como double[] e seria apenas double. Claro q aí vai dar erro

  • Obrigado 1

Compartilhar este post


Link para o post
Compartilhar em outros sites
5 minutos atrás, giu_d disse:

@giu_d Após fazer uma alteração de:


static double[] maxVec(double[] v)

para:


static double maxVec(double[] v)

Deu certo retornando "calc". Muito obrigado pela ajuda. 

 

  • Curtir 1

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Matheu Castelo  Que é isso! Fico feliz em poder ter ajudado. 

Abraço!

  • 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

×