C++:Product of Polynomials

这一次,你需要求两个多项式 A 和 B 的乘积(A×B)。

输入规范:

每个输入文件包含一个测试用例。每个测试用例占两行,每行描述一个多项式,格式为: K N1​ a N1 N2 aN2​​ ...... NK​ aNK​​ 其中 K 为多项式中非零项的个数,Ni和 aNi(i=1,2,⋯ ,Ki=1,2,⋯,K)分别表示幂次和系数。满足 1≤K≤10,0≤NK<⋯<N2<N1≤1000。

输出规范:

对于每个测试用例,输出一行,为 AA 与 BB 的乘积,格式与输入相同。注意行尾不得有多余空格。结果保留 1 位小数。

样例输入:

复制代码
2 1 2.4 0 3.2
2 2 1.5 1 0.5

样例输出:

复制代码
3 3 3.6 2 6.0 1 1.6
cpp 复制代码
#include <iostream>
#include <bits/stdc++.h>
#include <cstring>
#include <iomanip> 
using namespace std;
vector<int> v1,v2,v3;
map<int,double> mp,mp2,mp3;
bool cmp(int a,int b){
    return a>b;
}
int main(){
    int a,b;
    cin>>a;
    for(int i=0;i<a;++i){
        double xs;int mc;cin>>mc>>xs;
        mp[mc]=xs;
        v1.push_back(mc);
    }
    cin>>b;
    for(int i=0;i<b;++i){
        int mc;double xs;
        cin>>mc>>xs;
        mp2[mc]=xs;
        v2.push_back(mc);
    }
    for(int i=0;i<a;++i){
        for(int j=0;j<b;++j){
            int M=v1[i]+v2[j];
            double X=mp[v1[i]]*mp2[v2[j]];
            mp3[M]+=X;
            if(find(v3.begin(),v3.end(),M)==v3.end()){
                v3.push_back(M);
            }
        }
    }
    sort(v3.begin(),v3.end(),cmp);
    int cnt=0;
    for(int i=0;i<v3.size();++i){
        if(mp3[v3[i]]==0)cnt++;
    }
    cout<<v3.size()-cnt;

    for(int i=0;i<v3.size();++i){
        if(mp3[v3[i]]!=0)
        cout<<" "<<v3[i]<<" "<<fixed<<setprecision(1)<<mp3[v3[i]];
    }
    return 0;

}
相关推荐
无限进步_6 分钟前
【C++】私有虚函数与多态:访问权限不影响动态绑定
开发语言·c++·ide·windows·git·算法·visual studio
努力努力再努力wz8 分钟前
【MySQL入门系列】:不只是建表:MySQL 表约束与 DDL 执行机制全解析
android·linux·服务器·数据结构·数据库·c++·mysql
lolo大魔王13 分钟前
Go语言的结构体
开发语言·后端·golang
lly20240616 分钟前
C 作用域规则
开发语言
阿正的梦工坊17 分钟前
JavaScript 函数作用域详解——为什么函数外面访问不到里面的变量?
开发语言·javascript
艾莉丝努力练剑28 分钟前
【Linux加餐】mmap文件映射
linux·运维·服务器·c语言·c++·学习
DS数模29 分钟前
2026年Mathorcup数学建模竞赛A题思路解析+代码+论文
开发语言·数学建模·matlab·mathorcup·妈妈杯·2026妈妈杯
叶子野格34 分钟前
《C语言学习:编程例题》8
c语言·开发语言·c++·学习·算法·visual studio
Java面试题总结34 分钟前
Python 入门(四)- Openpyxl 操作 Excel 教程
开发语言·python·excel
6Hzlia38 分钟前
【Hot 100 刷题计划】 LeetCode 152. 乘积最大子数组 | C++ 动态规划 (绝妙 swap 翻转技巧)
c++·leetcode·动态规划