Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.53/15: Рейтинг темы: голосов - 15, средняя оценка - 4.53
0 / 0 / 0
Регистрация: 07.10.2018
Сообщений: 8

Составить программу табулирования функции

07.10.2018, 13:49. Показов 3000. Ответов 17
Метки c++ (Все метки)

Студворк — интернет-сервис помощи студентам
y = x0.2*tgx
Не могу понять как нужно написать эту функцию. Прошу помочь
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.10.2018, 13:49
Ответы с готовыми решениями:

Составить программу табулирования функции f(x)
Всем привет! Кому не тяжело, пожалуйста составьте программу, мне очень нужно на экзамен! Постановка задачи: составить программу...

Составить программу табулирования функции y (x)
Составить программу табулирования функции y (x), если x изменяется от xн к xк с шагом dx. Варианты к заданию приведены в таблице 1. ...

Составить программу табулирования функции
Помогите пожалуйста решить задачу! Составить программу для вычисления массива значений функции для различных значений аргумента,...

17
10 / 6 / 4
Регистрация: 03.10.2017
Сообщений: 110
07.10.2018, 14:06
Лучший ответ Сообщение было отмечено SSmersh как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include "stdafx.h"
#include <iostream>
using namespace std;
 
#define PI 3.1415926
 
double Func(double x)
{
    double t;
    t=pow(x, 0.2)*tan(x*PI/180);
    return t;
}
 
int main()
{
    double x,y;
    cout<<"Enter x : "; cin>>x;
    y=Func(x);
    cout<<y<<endl;
    system("pause");
    return 0;
}
1
1 / 1 / 0
Регистрация: 02.10.2018
Сообщений: 10
07.10.2018, 14:07
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <math.h>
#include <iostream>
 
int main()
{
  float x;
  float y;
  float z;
  setlocale(LC_CTYPE,"Russian");
  cout << "Введите число: ";
  cin >> x;
  z == pow (x, 0.2);
  y=z*tg(x);
  cout<<y;
  return 0; 
}
1
504 / 247 / 75
Регистрация: 31.10.2010
Сообщений: 747
07.10.2018, 15:26
Poteryan,
Цитата Сообщение от Poteryan Посмотреть сообщение
z == pow (x, 0.2);
, не верно, верно так:
C++
1
z = pow (x, 0.2);
1
1 / 1 / 0
Регистрация: 02.10.2018
Сообщений: 10
07.10.2018, 17:49
Я 2-жды проверял, я его стёр!!! Какого черта??!?!?!?
0
0 / 0 / 0
Регистрация: 07.10.2018
Сообщений: 8
07.10.2018, 20:02  [ТС]
Цитата Сообщение от ulyana_md Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include "stdafx.h"
#include <iostream>
using namespace std;
 
#define PI 3.1415926
 
double Func(double x)
{
    double t;
    t=pow(x, 0.2)*tan(x*PI/180);
    return t;
}
Выдает ошибку
0
10 / 6 / 4
Регистрация: 03.10.2017
Сообщений: 110
07.10.2018, 20:08
Какую ошибку выдает? У меня работает программа
Миниатюры
Составить программу табулирования функции  
0
0 / 0 / 0
Регистрация: 07.10.2018
Сообщений: 8
07.10.2018, 20:39  [ТС]
Вот ошибка
Миниатюры
Составить программу табулирования функции  
0
10 / 6 / 4
Регистрация: 03.10.2017
Сообщений: 110
07.10.2018, 21:02
Можно попробовать заменить библиотеку
C++
1
#include "stdafx.h"
на
C++
1
#include "pch.h"
и изменить путь файла, убрав все пробелы и кириллицу, в твоем случае пробелы. Больше никаких идей нет, как исправить ошибку
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
07.10.2018, 21:05
SSmersh, напишите формулу в редакторе формул, который расположен внизу или сбросьте скрин формулы
0
0 / 0 / 0
Регистрация: 07.10.2018
Сообщений: 8
07.10.2018, 22:18  [ТС]
https://www.cyberforum.ru/cgi-bin/latex.cgi?y ={x}^{0.2}tgx
Изображения
 
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
07.10.2018, 23:14
Лучший ответ Сообщение было отмечено SSmersh как решение

Решение

ulyana_md, возводится в степень и является аргументом tg одно и тоже число x, формула
Цитата Сообщение от ulyana_md Посмотреть сообщение
t=pow(x, 0.2)*tan(x*PI/180);
неправильна

SSmersh, без учёта области определения:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream> 
#include <cmath>
using namespace std;
 
int main()
{
    double x, y;
    y=pow(x,0.2)*tg(x);     
    cout<<"y="<<y<<endl;
    
system("pause");
return 0;
}
1
0 / 0 / 0
Регистрация: 07.10.2018
Сообщений: 8
08.10.2018, 07:56  [ТС]
Все работает спасибо
0
0 / 0 / 0
Регистрация: 07.10.2018
Сообщений: 8
21.10.2018, 12:02  [ТС]
Составить программу табулирования функции https://www.cyberforum.ru/cgi-bin/latex.cgi?y = {x}^{0.2}tgx
при изменении значения x от –1 до 1
с шагом 0,2
0
0 / 0 / 0
Регистрация: 07.10.2018
Сообщений: 8
21.10.2018, 18:57  [ТС]
. Составить программу табулирования функции . https://www.cyberforum.ru/cgi-bin/latex.cgi?y = {x}^{0.2}tgx
при изменении значения x от –1 до 1 с шагом 0,2
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,531
Записей в блоге: 1
21.10.2018, 19:09
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <iostream>
#include <cmath>
using namespace std;
double foo(double x) {
    if (x>1e-3)return tan(x)*exp(log(x)*0.2);
    if (x<-1e-3)return tan(x) /exp(log(-x)*0.2);
    return 0;
}
int main() {
    setlocale(LC_ALL, "rus");
    for (double x = -1; x <= 1; x += 0.2)
        cout << "f(" << x << ")=\t" << foo(x) << endl;
    return 0;
}
0
Мозгоправ
 Аватар для L0M
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
22.10.2018, 02:41
Наверное я выскажу общее мнение, что мы рады, что у ТС "всё работает"
Однако, остались некоторые вопросы.

Во-первых, функция то принимает вид pow(x, 0.2) * tg(x), то pow(x, 0.2 * tg(x)). Какой из них правильный?

Во-вторых, если исходить из первого варианта, ни хрена не понял, почему функция pow() при отрицательном основании и дробной степени меньшей 1 выдаёт -nan(ind)? В документации от MS такое поведение вообще никак не отмечается. С математической точки зрения,

https://www.cyberforum.ru/cgi-bin/latex.cgi?{x}^{0.2} \equiv \sqrt[5]{x}

и для корня нечётной степени отрицательный аргумент не помеха.

Теперь - к частностям.

Kuzia domovenok, по вашему варианту решения есть несколько вопросов.
  1. Почему вы решили, что в области размером 2e-3 с центром в нуле, значение функции будет 0? И откуда взялось это конкретное значение 1e-3?
  2. Почему во втором if в функции foo() у вас деление? Т.е. в первом if вы считаете функцию tg(x) * pow(x, 0.2), а во втором - tg(x) / pow(x, 0.2)?
  3. Мыши плакали, кололись, но продолжали сравнивать напрямую плавающие числа. Ну в этот раз вам повезло. А в следующий может и не повезти...

Ну и чтобы не быть обвинённым в огульной критике , выкладываю свой вариант.

Для облегчения жизни страждущим (а их много ), сделал отдельную функцию универсальный табулятор. На вход подаётся нижняя граница диапазона, верхняя граница диапазона, шаг приращения и указатель на испытуемую функцию. На выходе получаем щастье.

Кстати, Kuzia domovenok, обратите внимание, как в 24-й строке вычисляется значение аргумента для вызова функции. Это тоже к вопросу о точности вычислений с плавающими числами. Ваша программа на 6-й итерации в 0 не приходит - ошибочка от сложений накапливается.
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
#include <iostream>
#include <iomanip>
#include <cmath>
 
using namespace std;
 
typedef double(*funcPointer)(double);
 
double func(double x) {
    return x < 0 ?
        -1 * pow(-x, 0.2) * tan(x) :
        pow(x, 0.2) * tan(x);
}
 
void tabulator(double low, double high, double step, funcPointer f) {
    size_t steps = (size_t)((high - low) / step) + 1;
    double x;
    cout <<
        "+----------+----------------------+\n"
        "|     x    |         f(x)         |\n"
        "+----------+----------------------+\n";
 
    for (size_t i = 0; i < steps; ++i) {
        x = low + step * i;
        cout << "| " << setw(8) << setprecision(6) << x << 
            " | " << setw(20) << setprecision(15) << f(x) << " |" << endl;
    }
    cout <<
        "+----------+----------------------+\n";
}
 
int main() {
    tabulator(-1.0, 1.0, 0.2, func);
    tabulator(-1e-3, 1e-3, 2e-4, func);
    return 0;
}
Вывод на консоль. Первая табличка - по задаче, вторая - в окрестностях 0:
Code
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
+----------+----------------------+
|     x    |         f(x)         |
+----------+----------------------+
|       -1 |      1.5574077246549 |
|     -0.8 |    0.984697407915322 |
|     -0.6 |    0.617693750367354 |
|     -0.4 |    0.351997850328218 |
|     -0.2 |    0.146920111360069 |
|        0 |                    0 |
|      0.2 |     0.14692011136007 |
|      0.4 |    0.351997850328219 |
|      0.6 |    0.617693750367354 |
|      0.8 |    0.984697407915322 |
|        1 |      1.5574077246549 |
+----------+----------------------+
+----------+----------------------+
|     x    |         f(x)         |
+----------+----------------------+
|   -0.001 | 0.000251188726880539 |
|  -0.0008 |  0.00019217995043542 |
|  -0.0006 | 0.000136076005645084 |
|  -0.0004 | 8.36511686686976e-05 |
|  -0.0002 | 3.64112845460054e-05 |
|        0 |                    0 |
|   0.0002 | 3.64112845460054e-05 |
|   0.0004 | 8.36511686686976e-05 |
|   0.0006 | 0.000136076005645084 |
|   0.0008 |  0.00019217995043542 |
|    0.001 | 0.000251188726880539 |
+----------+----------------------+
1
0 / 0 / 0
Регистрация: 07.10.2018
Сообщений: 8
27.10.2018, 20:18  [ТС]
Нужно составить программу табулирования функции https://www.cyberforum.ru/cgi-bin/latex.cgi?y={x}^{0.2}tgx при изменении значения x от -1 до 1 с шагом 0.2
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.10.2018, 20:18
Помогаю со студенческими работами здесь

Составить программу табулирования функции y (x)
Составить программу табулирования функции y (x), если x изменяется от xн к xк с шагом dx. Варианты к заданию приведены в таблице 1. ...

Составить программу табулирования функции
Составить программу табулирования функции на отрезке с шагом h. Предусмотреть ОДЗ. За ранее благодарю.

Используя цикл с постусловием составить программу табулирования функции
1. Используя цикл с постусловием, составить программу табулирования функции f(x) = x sin x на отрезке с шагом h. Результат представить в...

Составить программу табулирования функции вида y=f(x) на различных интервалах [a,b] (a<b) с различными шагами h (h>0).
Составить программу табулирования функции вида y=f(x) на различных интервалах (a&lt;b) с различными шагами h (h&gt;0). Программа...

Написать программу табулирования функции f(x;y) в прямоугольник [a,b]*[c,d] с шагом табулирования h
Написать программу табулирования функции f(x;y) в прямоугольник * с шагом табулирования h=0.20. sin (x^2 + y/2), a=0, b=pi/2, c=0, d=pi/2.


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

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru