• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
村雨sup
自己选的路,跪着也要走完 XD
博客园    首页    新随笔    联系   管理    订阅  订阅
PAT 1002 A+B for Polynomials
1002 A+B for Polynomials (25 分)
 

This time, you are supposed to find A+B where A and B are two polynomials.

Input Specification:

Each input file contains one test case. Each case occupies 2 lines, and each line contains the information of a polynomial:

K N​1​​ a​N​1​​​​ N​2​​ a​N​2​​​​ ... N​K​​ a​N​K​​​​

where K is the number of nonzero terms in the polynomial, N​i​​ and a​N​i​​​​ (,) are the exponents and coefficients, respectively. It is given that 1,0.

Output Specification:

For each test case you should output the sum of A and B in one line, with the same format as the input. Notice that there must be NO extra space at the end of each line. Please be accurate to 1 decimal place.

Sample Input:

2 1 2.4 0 3.2
2 2 1.5 1 0.5

Sample Output:

3 2 1.5 1 2.9 0 3.2

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;


int main(){
    map<int,double> mp;
    map<int,double>::iterator it;

    int n;
    cin >> n;
    while(n--){
        int x;double y;
        cin >> x >> y;
        mp[x]+=y;
    }
    cin >> n;
    while(n--){
        int x;double y;
        cin >> x >> y;
        mp[x]+=y;
    }
    vector<pair<int,double>> vec;
    for(it=mp.begin();it!=mp.end();it++){
//        cout << it->first << " " << it->second << " ";
        if(it->second != 0) {
            vec.push_back(make_pair(it->first, it->second));
        }
    }
    cout << vec.size();
    for(int i=vec.size()-1;i >= 0;i--){
//        cout << vec[i].first << " " << fixed << setprecision(1)<< vec[i].second;
        printf(" %d %.1f",vec[i].first,vec[i].second);

    }

    return 0;
}

——map  make_pair vector 之间的骚操作。。

 
posted on 2019-04-07 01:48  村雨sup  阅读(80)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3