PAT刷题笔记-多项式相乘-1009 Product of Polynomials (25 分)

#include <iostream>
#include <cmath>
using namespace std;
#define  MAX 2000
#define EPS 1e-6
double res[MAX][MAX] = {0};
int max_a_index = 0, max_b_index = 0;//分别记录多项式的最高次数

void input(int N, double (&a)[MAX], int &index);

void output(int N1, double (&a)[MAX], int N2, double (&b)[MAX]);

int main() {

    double a[MAX] = {0}, b[MAX] = {0};
    int K1, K2;
    scanf("%d", &K1);
    input(K1, a, max_a_index);
    scanf("%d", &K2);
    input(K2, b, max_b_index);
    output(K1, a, K2, b);
}

void input(int N, double (&arr)[MAX], int &max_index) {
    int exp = 0;
    double coef = 0;
    for (int i = 0; i < N; ++i) {
        scanf("%d %lf", &exp, &coef);
        arr[exp] = coef;//指数exp对应的系数是coef
        if (max_index < exp) {//传入max_a_index,则记录a多项式的最高的次数,如果传入的是max_b_index,则记录的是多项式b的最高次数
            max_index = exp;
        }
    }
}
/*
 2 1 2.4 0 3.2
 2 2 1.5 1 0.5
 */
/*
 3 1 1 2 1 3 1
 3 1 1 3 -1 5 1
 */
void output(int N1, double (&a)[MAX], int N2, double (&b)[MAX]) {
    int i = 0, j = 0, count = 0;
    double sum = 0;
    //负责暂时存储左多项式的一个系数乘以右多项式的结果,每一行代表一个结果,m*n个结果存储到一个m*n的二维数组里面去
    for (i = 0; i <= max_a_index; ++i) {
        for (j = 0; j <= max_b_index; ++j) {
            if (abs(a[i]) > EPS && abs(b[j]) > EPS) {
                res[i][i + j] = a[i] * b[j];
            }
        }
    }
    //自上而下负责把对应系数相加,把m个多项式的结果相加到一起
    for (j = 0; j <= max_b_index + max_a_index; ++j) {//max_b_index=5
        for (i = 0; i <= max_a_index; ++i) {//max_a_index=3
            sum += res[i][j];
        }
        res[0][j] = sum;
        sum = 0;
    }
    //统计非零项个数
    for (i = 0; i <= max_a_index + max_b_index; ++i) {
        if (abs(res[0][i]) > EPS) {
            ++count;
        }
    }
    printf("%d", count);
    //从尾到头输出多项式的结果
    for (i = max_b_index + max_a_index; i >= 0; --i) {
        if (abs(res[0][i]) > EPS) {
            printf(" %d %.1f", i, res[0][i]);
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿维的博客日记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值