为什么pow(sum,1/2)`不能给我与`sqrt(sum))相同的结果?

问题描述 投票:1回答:1

在最后的代码中,在底部有一个名为general_norm的函数,它使用以下print()函数:

printf(" %f",sqrt(sum));
printf(" %f",pow(sum,1/2));

sqrt(sum))给我正确的结果,但我不理解为什么pow(sum,1/2)不考虑√x = x½

您能帮我弄清楚我所缺少的吗?谢谢! :-)

#include <stdio.h>
#include <math.h>


void print_vector(int N,float * V);
void save_vector(int N,float * V);
void absolute_values(int N,float * V, float * VABS);
void maximum_value(int N, float * VABS);
void general_norm(int N, float * VABS);


int main(void)
{

    const int n=4;
    int i;
    float v[n],vabs[n];

    puts("Enter the 5 components of the vector:");
    save_vector(n, v);

    puts("\nThe vector is:");
    print_vector(n, v);

    puts("\nThe absolute vector is:");
    absolute_values(n, v, vabs);

    puts("\nThe maximum value is:");
    maximum_value(n, vabs);

    puts("\nThe general norm is:");
    general_norm(n, vabs);

    return 0;
}

void save_vector(int N, float * V)
{
    int i;
    for(i=0;i<N;i++)
        scanf("%f",V+i);
}

void print_vector(int N, float * V)
{
    int i;
    for(i=0;i<N;i++)
        printf(" %.2f ",*(V+i));
}

void absolute_values(int N, float *V, float *VABS)
{
    int i;
    for(i=0;i<N;i++)
    {
        VABS[i]=((V[i]<0)?-V[i]:V[i]);
        printf(" %f", VABS[i]);
    }
}

void maximum_value(int N, float * VABS)
{
  int i;
  float maximum;
  maximum = VABS[0];

  for (i = 1; i < 4; i++)
  {
    if (VABS[i] > maximum)
    {
       maximum = VABS[i];
    }
  }
  printf(" %f", maximum);
}

void general_norm(int N, float * VABS)
{
  int i;
  float sum;

  for (i = 0; i < 4; i++)
    {
    sum=sum+pow(VABS[i],2);
    }
  printf(" %f",sqrt(sum));
  printf(" %f",pow(sum,1/2));
}
c square-root
1个回答
1
投票

只留下答案1201ProgramAlarm给了我:

整数数学。 1/20。请使用0.5,或强制键入1.0 / 2.0

1.0 / 2也可以。

最新问题
© www.soinside.com 2019 - 2024. All rights reserved.