вы должны понять, что знак '-' это не посто знак, а математическое действие,
уменьшающее число. причем в данном контексте под уменьшением понимается изменение значения в сторону отрицательного направления оси чисел.
Далее, вы должны понимать, что уравнение - это есть равенство величин, и если вы одну сторону уравнения изменяете на определённую величину, то для сохранения равенства (равновесия если взять за аналогию аптечные весы с гирями) вы обязаны изменить и вторую сторону уравнения на точно такую же величину.
Вот почему при переносе положительного числа из одной части в другую, оно меняет свой знак - ведь если вы его забрали из одной части, то и в ДРУГОЙ обязаны ОТНЯТЬ. И наоборот, если вы убрали из одной части отрицательное число - это то же самое, что добавить туда же такое же подожительное число, соответственно вы должны увеличить другую часть уравнения на такое же число.
1) #include <iostream>
#include <iomanip>
#include <cmath>
using namespace std;
int main()
{
setlocale(LC_ALL, "Russian");
srand(static_cast <unsigned> (time(NULL)));
int n = rand() % 16 + 5;
double * a = new double [ n ];
cout << "Дан массив [" << n << "]:" << endl;
cout.precision(2);
double s = 0, p = 1;
int imin = 0, imax = 0;
for (int i = 0; i < n; i++)
{
bool f;
do
{
a[ i ] = static_cast <double> (rand() % 1999 - 999) / 100;
int j = i - 1;
f = false;
while (!f && j >= 0)
{
f = a[ i ] == a[ j ];
j--;
}
} while (f);
cout << fixed << setw(8) << a[ i ];
if (a[ i ] > 0)
s += a[ i ];
if (fabs(a[ i ]) < fabs(a[ imin ]))
imin = i;
if (fabs(a[ i ]) > fabs(a[ imax ]))
imax = i;
}
cout << endl;
if (!s)
cout << "Положительных элементов нет" << endl;
else
cout << "Сумма положительных элементов: " << fixed << s << endl;
if (abs(imin - imax) < 2)
cout << "Между максимальным по модулю и минимальным по модулю нет элементов";
else
{
if (imin > imax)
{
imin ^= imax;
imax ^= imin;
imin ^= imax;
}
for (int i = imin + 1; i < imax; i++)
p *= a[ i ];
cout.precision(6);
cout << "Произведение элементов между макс. и мин. по модулю элементами: "
<< fixed << p;
}
cin.get();
delete [ ] a;
return 0;
}
2) прости не могу ответить
Пошаговое объяснение:
вы должны понять, что знак '-' это не посто знак, а математическое действие,
уменьшающее число. причем в данном контексте под уменьшением понимается изменение значения в сторону отрицательного направления оси чисел.
Далее, вы должны понимать, что уравнение - это есть равенство величин, и если вы одну сторону уравнения изменяете на определённую величину, то для сохранения равенства (равновесия если взять за аналогию аптечные весы с гирями) вы обязаны изменить и вторую сторону уравнения на точно такую же величину.
Вот почему при переносе положительного числа из одной части в другую, оно меняет свой знак - ведь если вы его забрали из одной части, то и в ДРУГОЙ обязаны ОТНЯТЬ. И наоборот, если вы убрали из одной части отрицательное число - это то же самое, что добавить туда же такое же подожительное число, соответственно вы должны увеличить другую часть уравнения на такое же число.