Форум программистов, компьютерный форум 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). Найти минимальный и максимальный элементы массива и упорядочить элементы по убыванию, стоящие между ними, методом «пузырька». подробнее

Показать сообщение отдельно
Ivanio
0 / 0 / 0
Регистрация: 13.03.2011
Сообщений: 31

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

06.03.2012, 12:50. Просмотров 428. Ответов 1
Метки (Все метки)

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
void Polynomials::print(){              // Вывод полинома
    int i;
    int k;                      // признак того, что очередной коэффициент равен 1
    int f;                      // признак того, что коэффициент - первый по счету (0 значит первый по счету)
    for(i=0,f=0;i<por+1;i++)        // пройти все коэффициенты
        if(koef[i]!=0){         // если очередной не равен нулю
            k=(koef[i]==1); // проверить его на равенство единице
            if(koef[i]>0){      // если больше нуля
                if(f) cout << " + "; // и не первый по счету коэффициент - вывести +
                f=1;            // установить признак того, что коэффициенты дальше - не первые
                if(!k || i==por) cout << koef[i]; // если коэффициент не равен 1 либо он стоит при нулевой степени - вывести его
            }
            else{               // коэффициент меньше нуля
                cout << " - ";  // вывест минус в любом случае
                f=1;            // установить признак того, что коэффициенты дальше - не первые
                if(!k || i==por) cout << (-koef[i]); // если коэффициент не равен 1 либо он стоит при нулевой степени - вывести его
            }
 
            if(!k && i!=por) cout << "*";   // если коэффициент не равен 1 и он не при нулевой степени икса - вывести знак умножения
            if(i!=por) cout << "x^" << por-i;   // если не нулевая степень икса - вывести икс в соответствующей степени 
        }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru