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

Упрощение кода - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Получить вывод команды оболочки - функция, обратная system() http://www.cyberforum.ru/cpp-beginners/thread513316.html
Доброго времени суток, товарищи! Расскажите, пожалуйста, существует ли в С++ функция, обратная по действию system(). То есть, если system() отправляет команду терминалу, то есть ли функция,...
C++ Как можно упростить exp^CA (если вводимые числа 5 и 4) Дана функция: Как можно упростить exp^CA(если вводимые числа 5 и 4), т.е C*A = 20 exp^20, не вводить ведь exp 20 раз Возможно ли упрощение данной формулы? http://www.cyberforum.ru/cpp-beginners/thread513306.html
Программирование рекурсий. Преобразование числа в двоичное C++
Дано целое неотрицательное число n. Преобразовать его в двоичное число.
C++ Отсортировать элементы, предшествующие первому нулевому элементу по возрастанию
Дан массив А(50). Отсортировать элементы, предшествующие первому нулевому элементу, по возрастанию алгоритмом «Сортировка вставками».
C++ Программирование рекурсий: отделить цифры данного числа и сложить межу собой http://www.cyberforum.ru/cpp-beginners/thread513274.html
Дано целое неотрицательное число n. Отделить цифры данного числа и сложить межу собой.
C++ Найти минимальный и максимальный элементы массива и упорядочить элементы по убыванию Дан массив А(40). Найти минимальный и максимальный элементы массива и упорядочить элементы по убыванию, стоящие между ними, методом «пузырька». подробнее

Показать сообщение отдельно
dimcoder
Полярный
466 / 439 / 68
Регистрация: 11.09.2011
Сообщений: 1,137
06.03.2012, 13:06
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
void Polynomials::print()
{                              // Вывод полинома
        int i;
        int k;                                          // признак того, что очередной коэффициент равен 1
        int f = 0;                                          // признак того, что коэффициент - первый по счету (0 значит первый по счету)
        for(i=0; i < por+1; i++)
        {                // пройти все коэффициенты
                k = (koef[i] == 1); // проверить его на равенство единице
                if(koef[i]>0)
                {          // если больше нуля
                    if(f) cout << " + "; // и не первый по счету коэффициент - вывести +
                    f=1;                    // установить признак того, что коэффициенты дальше - не первые
                    if(!k || i==por) cout << koef[i]; // если коэффициент не равен 1 либо он стоит при нулевой степени - вывести его
                }
                
                if (koef[i] < 0)
                {                           // коэффициент меньше нуля
                    cout << " - ";  // вывест минус в любом случае
                    f=1;                    // установить признак того, что коэффициенты дальше - не первые
                    if(!k || i==por) cout << (-koef[i]); // если коэффициент не равен 1 либо он стоит при нулевой степени - вывести его
                }
 
                if(!k && i!=por) cout << "*";   // если коэффициент не равен 1 и он не при нулевой степени икса - вывести знак умножения
                if(i!=por) cout << "x^" << por-i;       // если не нулевая степень икса - вывести икс в соответствующей степени 
        }
            
}
Можно еще убрать все ! перед k и сделать так:
C++
1
k=!(koef[i]==1);
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru