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

Вычислить выражение c++

18.11.2020, 13:24. Показов 813. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам

Вот код. Когда отлаживаю и ввожу переменные то далее ничего не происходит. Подскажите в чем не прав.
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
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
    int n, x, sumx, mult;
    cin >> n >> x;
    sumx = 0;
    mult = 1;
    for (int i = 1; i <= n; i++)
    {
        x = pow(x, (1 / i));
        sumx += x;
 
 
        for (int j = 2; j <= 2 * n; j + 2)
        {
 
            x = pow(abs(x + 1), 1 / i) + (pow(x, j) / n);
            mult *= x;
        }
        
    }
    cout << sumx * mult;
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.11.2020, 13:24
Ответы с готовыми решениями:

Вычислить выражение
Добрый день. Буду благодарен если кто нибудь набросает решение. Нужно вычислить выражение: \frac{n\left(n-1 \right)\, ...\,...

Вычислить выражение
Как записать y=\frac{1}{1+{e}^{-x}} ?

Вычислить выражение
вычислить выражение пожайлуста не сильно мудрите))) с решением

6
611 / 416 / 151
Регистрация: 11.01.2019
Сообщений: 1,746
18.11.2020, 14:10
Цитата Сообщение от JABA Посмотреть сообщение
1 / i
Это дает 0 при i > 1.
1
 Аватар для Annemesski
2670 / 1333 / 479
Регистрация: 08.11.2016
Сообщений: 3,682
18.11.2020, 14:29
строка 16: j + 2 заменить на j += 2
1
0 / 0 / 0
Регистрация: 05.10.2020
Сообщений: 27
22.11.2020, 12:40  [ТС]
Поправил код, выдает 0 если вводимые числа больше 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
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
    long double x, n;
    int sumx, mult;
    cin >> x >> n;
    sumx = 0;
    mult = 1;
 
    for (double i = 1; i <= n; i++)
    {
        x = pow(x, (1.0 / i));
        sumx += x;
 
 
        for (double j = 2; j <= 2 * n; j += 2)
        {
 
            x = pow(abs(x + 1), 1.0 / i) + (pow(x, j) / n);
            mult *= x;
        }
 
    }
    cout << sumx * mult;
 
    return 0;
}
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
22.11.2020, 13:24
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
#include <iostream>
#include <cmath>
using namespace std;
 
int main()
{
    int n;
    long double x, f, sum=0., mult;
    cin >> x >> n;   
 
    for (int i = 1; i <= n; i++)
    {                
        mult=1.;
        for (int j = 2; j <= 2*n; j+=2)
        { 
            f=pow(fabs(x+1.),1./i)+pow(x,j)/n;            
            mult*=f;
        }
        sum+=pow(x,1./i)*mult; 
    }
    
    cout << sum << "\n";
 
return 0;
}
2
41 / 26 / 17
Регистрация: 11.11.2019
Сообщений: 92
22.11.2020, 13:43
Цитата Сообщение от JABA Посмотреть сообщение
Поправил код, выдает 0 если вводимые числа больше 2. Как это исправить?
У Вас число становится слишком большим, что компьютеру просто не хватает выделенной памяти. Также, у вас изменяется х, что по условию неправильно. Либо вводите новую переменную, либо делаете все операции сразу с суммой и произведением.

Yetty, Я могу быть не прав, но, как мне кажется, по условию сначала мы получаем всю сумму, и всё произведение, и только после этого умножаем, а не сразу.
Я бы предложил такое решение:
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
#include <iostream>
#include <cmath>
using namespace std;
 
int main()
{
    long double x, n;
    int sumx, mult;
    cin >> x >> n;
    sumx = 0;
    mult = 1;
 
    for (int i = 1; i <= n; i++)
    {
        sumx += pow(x, (1.0 / i));
 
    }
 
    for (int j = 2, i = 1; j <= 2 * n; j += 2, i++)
    {
        mult *= pow(abs(x + 1), 1.0 / i) + (pow(x, j) / n);
    }
 
    cout << sumx * mult;
 
    return 0;
}
1
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
22.11.2020, 14:06
3alog, знак суммы относится ко всему выражению (хотя и нет общих скобок, но в произведении есть
переменная суммы i). то есть последовательно суммируются выражения (произведения x в степени на результат П) при i=1, i=2 и т.д. считаю Ваш вариант ошибочным

Цитата Сообщение от 3alog Посмотреть сообщение
int sumx, mult;
это тоже неправильно

ув. форумчане ! просьба к тем, кто разбирается в этом вопросе высказать своё мнение
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.11.2020, 14:06
Помогаю со студенческими работами здесь

Вычислить выражение 1+2+3+n
Помогите написать программу в C++ (1+2+3+n)/n

Вычислить выражение
X-ввести

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

Вычислить выражение
2. Вычислить выражение 33(x^2)/4

Вычислить выражение
3.Вычислить выражение x^3+y +|y|


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru