随机生成一个正整数集合,集合中的数各不相同,求:其中有多少个数,恰好等于集合中另外两个(不同的)数之和。 输入格式: 第一行:输入一个正整数n,表示集合中元素的个数。 第二行:集合中的n个正整数 输出格式:一个整数,表示有多少个数,恰好等于集合中另外两个(不同的)数之和。C语言
时间: 2024-12-15 09:13:29 浏览: 19
为了在C语言中解决这个问题,我们可以使用哈希表(如`unordered_set`或`std::set`)存储集合中的每个元素及其出现次数,并遍历整个集合。对于每个元素,我们检查它是否能等于其他两个不同的元素之和。如果找到匹配,我们就增加计数。
以下是一个简单的C++代码示例:
```cpp
#include <iostream>
#include <vector>
#include <unordered_set>
int find_pairs(std::vector<int>& nums) {
std::unordered_set<int> numSet(nums.begin(), nums.end());
int count = 0;
for (const auto& num : nums) {
if (numSet.find(num * 2 - nums[0]) != numSet.end() && num != num * 2 - nums[0]) {
++count;
}
// 检查是否等于当前数的一半 + 另外一个数
for (size_t i = 1; i < numSet.size(); ++i) {
int complement = numSet.find(num * 2 - (*numSet.rbegin() + i));
if (complement != numSet.end() && num != complement) {
++count;
}
}
}
return count;
}
int main() {
int n;
std::cin >> n;
std::vector<int> nums(n);
for (auto& num : nums) {
std::cin >> num;
}
int result = find_pairs(nums);
std::cout << "集合中有 " << result << " 个数恰好等于集合中另外两个不同的数之和。\n";
return 0;
}
```
在这个程序中,`find_pairs`函数接收一个整数向量作为输入,计算并返回满足条件的数字对的数量。注意,这个算法假设输入集合中的所有元素都是非负整数,且集合中的最大值不大于最小值的两倍。
阅读全文