#include<bits/stdc++.h>
using namespace std;
int main() {
#ifdef ONLINE_JUDGE
#else
freopen("in.txt", "r", stdin);
#endif
vector<double> a(1010, 0);
int k1, k2, cnt = 0;
scanf("%d", &k1);
while (k1--) {
int e;
double c;
scanf("%d %lf", &e, &c);
a[e] += c;
}
scanf("%d", &k2);
while (k2--) {
int e;
double c;
scanf("%d %lf", &e, &c);
a[e] += c;
}
for (int i = 0; i < 1010; ++i) {
if (a[i]) {
++cnt;
}
}
printf("%d", cnt);
for (int i = 1001; i >= 0; --i) {
if (a[i]) {
printf(" %d %.1f", i, a[i]);
}
}
return 0;
}
第一遍13/25分,发现最后输出的地方,我是从cnt-1输出到0的,但实际上这几个项不一定连在一起,样例刚好是这样而已,修改了多了2个2分的测试点,17分。
然后注意到题目里没有说明都是正数,也许中间相加的时候会出现零项,我原来的cnt计数方法是边读数边累加,如果当时加的数组位置是0,则++cnt。改成最后计算cnt后,剩下的4个2分点就都过了。