一元多项式的运算

 #include <iostream>
using namespace std;


struct Infor
{
 int coef;
 int exp;

 struct Infor *next;
};

int main()
{
 int  i = 0, j, k;
 char word;
 struct Infor *p1 = new struct Infor;
 struct Infor *p2 = p1;
 struct Infor *p = NULL;
 struct Infor *p3 = NULL, *p4 = NULL;
 p1->next = NULL;

 freopen("1.txt", "r", stdin);

 cin >> word;
 p = new struct Infor;
 cin >> p->coef >> p->exp;

 while (0 != p->coef)
 {
  p2->next = p;
  p2 = p;
  p->next = NULL;

  p = new struct Infor;
  cin >> p->coef >> p->exp;
 }

 cin >> word;
 p3 = new struct Infor;
 cin >> p3->coef >> p3->exp;

 while (0 != p3->coef)
 {
  p = p1->next;

  while(NULL != p && p->exp != p3->exp)
  {
   p = p->next;
  }

  if (NULL == p)       //A 中没有 B 的项就直接加入
  {
   p4 = new struct Infor;
   p2->next = p4;
   p4->next = NULL;
   p2 = p4;

   p2->coef = p3->coef;
   p2->exp = p3->exp;
  }
  else         //执行加法运算
  {
   p->coef += p3->coef;
  }

  p3 = new struct Infor;
  cin >> p3->coef >> p3->exp;
 }


 int temp = 0, MaxSize = 0;
 int nArray[100] = {0}, nArray2[100] = {0};
 p = p1->next;

 for (; NULL != p; p = p->next)
 {
  if (p->coef != 0)
  {
   nArray[MaxSize] = p->coef;
   nArray2[MaxSize] = p->exp;
   MaxSize++;
  }
 }


 for (i = 0; i < MaxSize; i++)
 {
  k = i;
  for (j = k+1; j < MaxSize; j++)
  {
   if (nArray2[i] > nArray2[j])
   {
    temp = nArray[i];
    nArray[i] = nArray[j];
    nArray[j] = temp;

    temp = nArray2[i];
    nArray2[i] = nArray2[j];
    nArray2[j] = temp;
   }
  }
 }

 cin >> word;

 for (i = 0; i < MaxSize; i++)
 {
  cout << nArray[i] << " " << nArray2[i] << endl;
 }
 
 
 return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值