Форум программистов, компьютерный форум CyberForum.ru

проверка функций - C++

Восстановить пароль Регистрация
 
Mr. Pyatachok
 Аватар для Mr. Pyatachok
8 / 8 / 0
Регистрация: 30.06.2011
Сообщений: 250
28.01.2012, 22:35     проверка функций #1
Всем привет!
Вот проблема:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#include<iostream.h>
#include<conio.h>
#include<math.h>
 
struct Angle
{
    int degree;
    int minute;
};
 
void Init(Angle& angle,int d,int m)
{
    angle.degree=d;
    angle.minute=m;
}
 
void Read(Angle& angle)
{
    cout<<"Введите значение градусов: ";
    cin>>angle.degree;
    cout<<"Введите значение минут: ";
    cin>>angle.minute;
}
 
float Transfer_in_degrees(Angle& angle)
{
    return (angle.degree+angle.minute/60.0);
}
 
float Transfer_in_radians(Angle& angle)
{
    return Transfer_in_degrees(angle)*M_PI/180.0;
}
 
float Sin_of_angle(Angle& angle)
{
    return sin(Transfer_in_radians(angle));
}
 
float Transfer_in_normal_form(Angle& angle)
{
    return (Transfer_in_degrees(angle)/360.0-int(Transfer_in_degrees(angle)/360.0))*360.0;
}
 
void Display(Angle& angle)
{
    cout<<"Вы ввели следующие значения:"<<endl;
    cout<<"Градусы: "<<angle.degree<<endl;
    cout<<"Минуты:  "<<angle.minute<<endl;
    cout<<"Перевод в градусы: "<<Transfer_in_degrees(angle)<<endl;
    cout<<"Перевод в радианы: "<<Transfer_in_radians(angle)<<endl;
    cout<<"Синус угла: "<<Sin_of_angle(angle)<<endl;
    cout<<"Перевод к нормальному виду (0-360): "<<Transfer_in_normal_form(angle)<<endl;
}
 
int main()
{
   Angle angle;
   Init(angle,1,2);
   Read(angle);
   Display(angle);
 
   getch();
   return 0;
}
Подскажите пожалуйста, ребята, почему выбивает ересь в синусе и переводе к нормальному виду (мусор какой-то при вводе значений кратных 180 градусам и 0 минут)?

Проверьте пожалуйста внешние функции)
Заранее благодарен!!!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
AzaKendler
 Аватар для AzaKendler
214 / 116 / 9
Регистрация: 30.05.2011
Сообщений: 1,772
29.01.2012, 00:43     проверка функций #2
чтоб был русский надо локаль консольке поменять.


C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#include<iostream>
#include<conio.h>
#include<math.h>
#include <iomanip>
#include <locale> //подключаем
 
using std::end;
using std::cout;
using std::cin;
using std::endl;
using std::locale;
 
 
 const double M_PI = 3.14159265;
struct Angle
{
        int degree;
        int minute;
        
};
 
void Init(Angle& angle,int d,int m)
{
        angle.degree=d;
        angle.minute=m;
}
 
void Read(Angle& angle)
{
        cout<<"Введите значение градусов: ";
        cin>>angle.degree;
        cout<<"Введите значение минут: ";
        cin>>angle.minute;
}
 
float Transfer_in_degrees(Angle& angle)
{
        return (angle.degree+angle.minute/60.0);
}
 
float Transfer_in_radians(Angle& angle)
{
        return Transfer_in_degrees(angle)*M_PI/180.0;
}
 
float Sin_of_angle(Angle& angle)
{
        return sin(Transfer_in_radians(angle));
}
 
float Transfer_in_normal_form(Angle& angle)
{
        return (Transfer_in_degrees(angle)/360.0-int(Transfer_in_degrees(angle)/360.0))*360.0;
}
 
void Display(Angle& angle)
{
        cout<<"Вы ввели следующие значения:"<<endl;
        cout<<"Градусы: "<<angle.degree<<endl;
        cout<<"Минуты:  "<<angle.minute<<endl;
        cout<<"Перевод в градусы: "<<Transfer_in_degrees(angle)<<endl;
        cout<<"Перевод в радианы: "<<Transfer_in_radians(angle)<<endl;
        cout<<"Синус угла: "<<Sin_of_angle(angle)<<endl;
        cout<<"Перевод к нормальному виду (0-360): "<<Transfer_in_normal_form(angle)<<endl;
}
 
int main()
{
    locale::global(locale("RUS")); //пользуем
   Angle angle;
   Init(angle,1,2);
   Read(angle);
   Display(angle);
 
   getch();
   return 0;
}
не спеши. проверь. я ток поправил чтоб компилилось хотя бы и русский вывело. остальное не смотрел
Mr. Pyatachok
 Аватар для Mr. Pyatachok
8 / 8 / 0
Регистрация: 30.06.2011
Сообщений: 250
29.01.2012, 00:53  [ТС]     проверка функций #3
Вопрос в функциях, корректно ли они работать будут?

Добавлено через 2 минуты
За русский отдельное спасибо))

Добавлено через 1 минуту
AzaKendler, проверьте пожалуйста, а то когда ввожу 180 градусов и 0 минут 2 последние функции бред выводят
AzaKendler
 Аватар для AzaKendler
214 / 116 / 9
Регистрация: 30.05.2011
Сообщений: 1,772
29.01.2012, 01:03     проверка функций #4
C++
1
cout<<sin(180.0);

C++
1
2
3
4
float Transfer_in_radians(Angle& angle)
{
        return Transfer_in_degrees(angle)*M_PI/180.0;// 180*3.14159265/180 == 3.14159265
}


C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//.................
#include <ios>
using std::ios_base;
 
 
 
int main()
{
 locale::global(locale("RUS")); //пользуем
cout.setf(ios_base::floatfield,ios_base::fixed);// попробуй
   Angle angle;
   Init(angle,1,2);
   Read(angle);
   Display(angle);
 
   getch();
   return 0;
}
Paporotnik
383 / 227 / 7
Регистрация: 06.07.2011
Сообщений: 512
29.01.2012, 01:11     проверка функций #5
это не бред, а то значение, которое высчитала ф-ция синуса с учетом ограничений точности типа float. нуля там не получишь - придется довольствоваться "очень малым числом". воспользуешься типом double - получишь еще более малое число.
если уж так хочется видеть нули в результатах, то введите некую точность, ниже которой значение будет считаться нулевым и присваивай значение явно.
AzaKendler
 Аватар для AzaKendler
214 / 116 / 9
Регистрация: 30.05.2011
Сообщений: 1,772
29.01.2012, 01:14     проверка функций #6
Paporotnik, да пусть просто формат вывода поменяет. Я накидал как
Mr. Pyatachok
 Аватар для Mr. Pyatachok
8 / 8 / 0
Регистрация: 30.06.2011
Сообщений: 250
29.01.2012, 01:28  [ТС]     проверка функций #7
Paporotnik, т.е. у меня все правильно?
Помогите, если Вам нетяжело с этой "точность, ниже которой значение будет считаться нулевым и присваивай значение явно", я просто не совсем понимаю как это написать

Спасибо за объяснение!!!

Добавлено через 11 минут
простите за тупость, но что значит cout.setf(ios_base::floatfield,ios_base::fixed); ?
я так понимаю и с остальными типами можно так,или я не прав?
если нетяжело киньте ссылочку чтобы понятным языком было описано все)
работает вес, огромное спасибо))
Paporotnik
383 / 227 / 7
Регистрация: 06.07.2011
Сообщений: 512
29.01.2012, 01:29     проверка функций #8
C++
1
2
3
4
5
6
7
8
double epsilon = 0.0000001;
...
float Sin_of_angle(Angle& angle)
{
        double res=sin(Transfer_in_radians(angle));
        if (res<epsilon) return 0;
        else return res;
}
хотя смысла в этом мало и в серьезных приложениях, думаю, нужен совсем другой подход.
IGPIGP
Комп_Оратор)
 Аватар для IGPIGP
6171 / 2900 / 284
Регистрация: 04.12.2011
Сообщений: 7,712
Записей в блоге: 3
29.01.2012, 02:31     проверка функций #9
Готов поспорить, что есть и еще кое-что - смотрите:

Цитата Сообщение от Mr. Pyatachok Посмотреть сообщение
return (angle.degree+angle.minute/60.0);
если вычислить выражение в скобках, учитывая, что angle.degree и angle.minute - целые, то по идее:
angle.minute/60.0=0
+angle.degree=angle.degree
потом return приводит результат: angle.degree к типу float.
А не надежнее ли может:
C++
1
2
3
float degree=angle.degree;
flоаt minute=angle.minute;
return degree+minute/60.0;
ну а если не хочется 2-х "лишних" переменных - можно явно преобразовать типы в выражении
return ... хотя память под float выделяться будет в том же стеке при выполнении чего-то типа
((float)angle.minute)/60.0
и подобное у Вас в нескольких местах... Но исправить то легко
NoMasters
Псевдослучайный
1737 / 1080 / 69
Регистрация: 13.09.2011
Сообщений: 3,093
29.01.2012, 02:36     проверка функций #10
IGPIGP, ты не прав. 60.0 вещественное и, учитывая приоритет операций, этого достаточно.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.01.2012, 02:47     проверка функций
Еще ссылки по теме:

C++ Объявление функций внутри других функций
C++ Использование функций и шаблонов функций
шаблоны функций C++

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

Или воспользуйтесь поиском по форуму:
IGPIGP
Комп_Оратор)
 Аватар для IGPIGP
6171 / 2900 / 284
Регистрация: 04.12.2011
Сообщений: 7,712
Записей в блоге: 3
29.01.2012, 02:47     проверка функций #11
Цитата Сообщение от NoMasters Посмотреть сообщение
IGPIGP, ты не прав. 60.0 вещественное и, учитывая приоритет операций, этого достаточно.
Верно 60.0... не заметил, прошу прощения.
Yandex
Объявления
29.01.2012, 02:47     проверка функций
Ответ Создать тему
Опции темы

Текущее время: 09:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru