Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 65, средняя оценка - 4.86
koperfild
9 / 9 / 3
Регистрация: 04.12.2011
Сообщений: 137
#1

abs(float x) - C++

18.01.2012, 18:24. Просмотров 8934. Ответов 7
Метки нет (Все метки)

Я не понимаю почему но у меня функция abs возвращает модуль от int чисел и всегда 0 от double чисел. В чём может быть проблема?Хотя вот в данном примере частное a/b получается, но как-то без знаков после запятой, а abs(b) стабильно 0.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <stdio.h>
#include <stdlib.h>
 
int main(){
int k,l;
double a,b;
k=233;
l=-122;
a=10.230;
b=0.02315;
k=abs(k);
l=abs(l);
a=abs(a/b);
b=abs(b);
printf ("%d %d %lf %lf",k,l,a,b);
scanf("%d",&k);
return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.01.2012, 18:24
Здравствуйте! Я подобрал для вас темы с ответами на вопрос abs(float x) (C++):

std::abs vs global abs - C++
Откуда растут ноги такого поведения, что std::abs возвращает double, а глобальная ::abs() - int ? #include &lt;iostream&gt; #include &lt;cmath&gt; ...

опять ошибка.на этот раз cannot convert `float (*)(float)' to `float' in argument passing - C++
#include&lt;stdio.h&gt; #include&lt;stdlib.h&gt; #include&lt;math.h&gt; float f1(float x)/*vira*enie 1*/ {return (x*cos(x))/(1+ pow(x,2));} ...

Чем отличаются float преобразования (float)var от float(var) - C++
Здравствуйте! Подскажите, чем отличается (float)var от float(var)

неверное приведение void* к *float а далее к float - C++
Почему когда привожу void* к int* потом к int то все работает, данные не бьются и работают нормально, когда делаю те же операции но с...

cannot convert `float' to `float*. Почему так происходит? - C++
всем привет, помогите исправить ошибки... а то голова мало варит уже, а завтра надо сдать уже #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt;...

invalid types `float[float]' for array subscript - C++
void SEARCH(float vol, float price, int i) { if (i&gt;N) { if(price&gt;maxprice) { ...

7
soon
2542 / 1307 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
18.01.2012, 18:27 #2
fabs
0
koperfild
9 / 9 / 3
Регистрация: 04.12.2011
Сообщений: 137
18.01.2012, 18:59  [ТС] #3
Т.е. компилятор может не поддерживать с++ функцию abs для double?
0
soon
2542 / 1307 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
18.01.2012, 19:04 #4
Цитата Сообщение от koperfild Посмотреть сообщение
Т.е. компилятор может не поддерживать с++ функцию abs для double?
Дак у вас Сишный код. А на плюсах так будет
C++
1
2
3
4
5
6
7
8
#include <iostream>
#include <cmath>
 
int main()
{
    std::cout << std::abs(-1.2) << std::endl;
    return 0;
}
0
go
Эксперт С++
3586 / 1366 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
18.01.2012, 19:08 #5
Цитата Сообщение от koperfild Посмотреть сообщение
Т.е. компилятор может не поддерживать с++ функцию abs для double?
Есть две перегруженные функции
C++
1
2
int abs ( int n );
long abs ( long n );
Можете дописать еще свою

Добавлено через 2 минуты

Не по теме:

soon, всегда думал, что abs() в cstdlib описан



Добавлено через 48 секунд
В cmath есть и такая перегрузка
C++
1
2
3
double abs (      double x );
      float abs (       float x );
long double abs ( long double x );
0
soon
18.01.2012, 19:11
  #6

Не по теме:

Цитата Сообщение от go Посмотреть сообщение
soon, всегда думал, что abs() в cstdlib описан
Там не std::abs().

0
koperfild
9 / 9 / 3
Регистрация: 04.12.2011
Сообщений: 137
19.01.2012, 13:19  [ТС] #7
Ещё 1 вопрос. В проге есть проверка на то пустой ли файл
C++
1
2
3
4
if (fscanf(in,"%lf",&k)==0){
   perror("file pyst");
   exit (-1);
}
Я поставил после этого для проверки printf ("%lf",k) и эта k при действительно пустом файле почему то получается большим целым числом(что-то около 6 символов). Хотя вроде как конец файла это -1. Почему так
0
go
Эксперт С++
3586 / 1366 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
19.01.2012, 13:23 #8
koperfild, fscanf возвращает ноль, значит было присвоено 0 значений. Вывод: в k ничего не записывалось, и в нем хранится "прошлое" значение. Если до этого k не инициализировали, то там хранится мусор, который вы выводите (если, конечно, k - локальная переменная).
1
19.01.2012, 13:23
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.01.2012, 13:23
Привет! Вот еще темы с ответами:

Ошибка cannot convert 'float' to 'float*' - C++
Здравствуйте, что означает error: cannot convert 'float' to 'float*' for argument '1' to 'int mas_time(float*, int)'? Из-за чего она...

Function abs - C++
Ошибка 1.error C2668: abs: неоднозначный вызов перегруженной функции строка 12 Ошибка 2.error C2668: abs: неоднозначный вызов...

Pow and ABS problems - C++
Задали протабулировать функцию вот код, ошибки в pow, abs // 333333.cpp : Defines the entry point for the console application. // ...

ОШИБКА [Error] cannot convert 'int*' to 'float*' for argument '1' to 'void Syma(float*,int*,int) - C++
Какая то проблема с указателями,незнаю,не хочет щитать суму парних чисел в второй подпрограме.Извиниет за ошибки.Не владею руским.Помогите...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru