|
常用链接
留言簿(30)
随笔分类(128)
随笔档案(169)
文章分类
文章档案(3)
others
something special
经典的c/c++
搜索
积分与排名
最新评论
data:image/s3,"s3://crabby-images/93320/93320ba8164624c7c09e7cba1edb2fec259b84ff" alt=""
阅读排行榜
评论排行榜
Powered by: 博客园
模板提供:沪江博客
|
|
|
|
|
发新文章 |
|
|
1data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" /**//******************************************************************** 2 created: 2005/12/21 3 created: 21:12:2005 10:49 4 filename: poly.h 5 author: Liu Qi 6data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt="" 7 purpose: 多项式相关操作的接口与实现 8 *********************************************************************/ 9 #ifndef POLY_H 10 #define POLY_H 11data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 12data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 13 #include <stdio.h> 14 #include <assert.h> 15 #include "../sllist.h" 16data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 17data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 18 typedef List PolynomialList; 19data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 20data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" /**//*=========================================================================== 21 * Function name: PolynomialAdd 22 * Parameter: lhs:多项式 23 * Precondition: NULL != lhs && NULL != rhs, NULL != lhs->Next && NULL != rhs->Next 24 * Description: 返回一个新的多项式头指针 25 * Return value: 26 * Author: Liu Qi, [12/21/2005] 27 ===========================================================================*/ 28 PolynomialList PolynomialAdd(PolynomialList lhs, PolynomialList rhs) 29data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" { 30 Position lhsPos = lhs->Next; //指向第一个多项式的第一个元素 31 Position rhsPos = rhs->Next; //指向第二个多项式的第一个元素 32 PolynomialList retPolynomialList= SLL_Create(); 33 ElemType Elem; 34 35 assert( NULL != lhs && NULL != rhs ); 36 assert( NULL != lhs->Next && NULL != rhs->Next ); 37 38 while (NULL != lhsPos && NULL != rhsPos) 39data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" { 40 //第一个多项式的指数大,复制第一个多项式的一个节点插入到retPolynomialList头部 41 if ((lhsPos->Element.HighPower) > (rhsPos->Element.HighPower)) 42data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" { 43 Elem.coef = lhsPos->Element.coef; 44 Elem.HighPower = lhsPos->Element.HighPower; 45 SLL_PushFront(Elem, retPolynomialList); 46 lhsPos = SLL_NextPos(lhsPos); 47 } 48 else if ((lhsPos->Element.HighPower) < (rhsPos->Element.HighPower)) 49data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" { 50 Elem.coef = rhsPos->Element.coef; 51 Elem.HighPower = rhsPos->Element.HighPower; 52 SLL_PushFront(Elem, retPolynomialList); 53 rhsPos = SLL_NextPos(rhsPos); 54 } 55 else //指数相等 56data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" { 57 Elem.coef = lhsPos->Element.coef + rhsPos->Element.coef; 58 Elem.HighPower = lhsPos->Element.HighPower; 59 SLL_PushFront(Elem, retPolynomialList); 60 lhsPos = SLL_NextPos(lhsPos); 61 rhsPos = SLL_NextPos(rhsPos); 62 } 63 } 64 65 while (NULL != lhsPos) 66data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" { 67 Elem.coef = lhsPos->Element.coef; 68 Elem.HighPower = lhsPos->Element.HighPower; 69 SLL_PushFront(Elem, retPolynomialList); 70 lhsPos = SLL_NextPos(lhsPos); 71 } 72 73 while (NULL != rhsPos) 74data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" { 75 Elem.coef = rhsPos->Element.coef; 76 Elem.HighPower = rhsPos->Element.HighPower; 77 SLL_PushFront(Elem, retPolynomialList); 78 rhsPos = SLL_NextPos(rhsPos); 79 } 80 81 return retPolynomialList; 82 } 83data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 84 #endif 85data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt="" 测试代码:
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
#include <stdio.h>
#include "poly.h"
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
void PrintPolynomial(PolynomialList L)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
Position pos = L->Next;
assert (NULL != L);
for ( ; NULL != pos; pos = pos->Next)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt="" {
printf("%dX^%d + ", pos->Element.coef, pos->Element.HighPower);
}
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
printf("\n");
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int main()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt="" data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt="" {
Polynomial p;
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
PolynomialList p1 = SLL_Create();
PolynomialList p2 = SLL_Create();
PolynomialList result = NULL;
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
// P1(X) = X^2 + 2X + 3
p.coef = 3;
p.HighPower = 0;
SLL_PushFront(p, p1);
p.coef = 2;
p.HighPower = 1;
SLL_PushFront(p, p1);
p.coef = 1;
p.HighPower = 2;
SLL_PushFront(p, p1);
PrintPolynomial(p1);
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
// P2(X) = 3X^3 + 10X + 6
p.coef = 6;
p.HighPower = 0;
SLL_PushFront(p, p2);
p.coef = 10;
p.HighPower = 1;
SLL_PushFront(p, p2);
p.coef = 3;
p.HighPower = 3;
SLL_PushFront(p, p2);
PrintPolynomial(p2);
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
result = PolynomialAdd(p1, p2);
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
PrintPolynomial(result);
data:image/s3,"s3://crabby-images/6c6b8/6c6b84e662455f8092d9c42e3a86036cd3a28be1" alt=""
SLL_DeleteList(p1);
SLL_DeleteList(p2);
SLL_DeleteList(result);
return 0;
}
|
|