本文介绍: 这里面用了pair,如果不了解的,可以看一下妾身这一篇。不断匹配相乘累加就好了。

 不断匹配相乘累加就好了

#include<iostream>
#include<vector&gt;
#include <utility&gt;
using namespace std;

int main() {
	int n;
	int a, b;
	long long result=0; // 使用 long long  
	cin &gt;&gt; n &gt;&gt; a &gt;&gt; b;

	vector<pair<int, int&gt; > u, v;
	int index, value;

	for (int i = 0; i < a; i++) {
		cin >> index >> value;
		u.push_back({ index, value });
	}

	for (int i = 0; i < b; i++) {
		cin >> index >> value;
		v.push_back({ index, value });
	}

	int i = 0, j = 0;
	while (i < a &amp;&amp; j < b) {
		if (u[i].first == v[j].first) {
			result += u[i].second * v[j].second;
			i++; j++;
		}
		else if (u[i].first > v[j].first) {
			j++;
		}
		else {
			i++;
		}
	}

	cout << result << endl;

	return 0;
}

里面用了pair,如果不了解的,可以看一下妾身这一篇C++中的pair

 谢谢大家

原文地址:https://blog.csdn.net/jsjsjejsj/article/details/134767554

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_38936.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注