КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Пример. Сложение многочленов
В этом примере исходными данными являются два многочлена от трех переменных: Априорно известно, что лишь немногие из коэффициентов этих полиномов отличны от нуля. Если воспользоваться прямоугольными массивами для хранения коэффициентов многочленов, то, во-первых, основной объем памяти будет потрачен на хранение нулей, а, во-вторых, основное время работы алгоритма будет потрачено на сложение с нулем и умножение на нуль. В данном примере полином представлен линейным односвязным циклическим списком с головой. Структура узла имеет вид: struct NODE{ float A; // коэффициент при одночлене int px,py,pz; // степени x,y,z NODE *next; };
Многочлен 3x2y2z+8x2y3z2-7x3yz4 будет представлен списком, изображенным на рис.9. Рис.9. Многочлен в списке
Будем полагать, что показатели степеней ijk переменных следуют в списке в порядке возрастания (лексикографический порядок). Для сравнения степеней используется функция, возвращающая –1, 0,+1: int PowerCmp(NODE *p, NODE *q){ if(p->px>q->px) return 1; if(p->px<q->px) return -1; if(p->py>q->py) return 1; if(p->py<q->py) return -1; if(p->pz>q->pz) return 1; if(p->pz<q->pz) return -1; return 0; }
В поле ijk головы списка поместим максимально возможные значения (INT_MAX (см. файл limits.h)). Зачем это нужно будет ясно позднее. Алгоритм выполняет операцию P=P+Q, то есть результат сложения будет получен на месте первого многочлена. void PoliAdd(NODE *p, NODE *q){ // p,q - головы списков многочленов-слагаемых // p=p+q NODE *p1,*p2,*q1; NODE *x; for(p1=p,p2=p1->next,q1=q->next; q1!=q;){ switch(PowerCmp(p2,q1)){ case 1: // p2>q1 x=new NODE; memcpy(x,q1,sizeof(NODE)); // вставка вслед за p1 x->next=p2; p1->next=x; p1=x; p2=p1->next; q1=q1->next; break; case -1: // p2<q1 p1=p2; p2=p2->next; break; case 0: // p2==q1 p2->A+=q1->A; if(fabs(p2->A)<1e-7){ // удалить p2 p1->next=p2->next; delete p2; p2=p1->next; } else { p1=p2; p2=p2->next; } q1=q1->next; break; } //switch } // for } Отметим, что приведенном алгоритме нет необходимости специально обрабатывать ситуацию, когда список p закончился, а список q нет. В головы списков помещены максимально возможные значения степеней, поэтому, когда закончится список p, его голова "пропустит" вперед себя весь остаток списка q.
Дата добавления: 2014-12-08; Просмотров: 620; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |