输入)定义一个整型数组array和一个整数target,找出(输出)数组array中两个数的和与乘为target的所有组合
时间: 2024-10-07 10:03:46 浏览: 24
这个问题是在寻找数组`array`中的两个元素,它们的和与积分别等于给定的目标值`target`。这是一个经典的算法题目,通常可以通过哈希集合(如Python的set)或者双指针法来解决。以下是使用Python的一个简单示例:
```python
def find_two_numbers(array, target):
# 创建一个空集合存储已访问过的数字
seen = set()
# 使用两层循环遍历所有可能的配对
for i in range(len(array)):
complement = target - array[i]
# 检查目标值的补数是否已经在集合中
if complement in seen:
return [array[i], complement] # 如果找到,返回这两个数
else:
seen.add(array[i]) # 更新已访问集合
# 如果找不到符合条件的配对,返回None或抛出异常
return None
# 示例数组和目标值
array = [2, 7, 11, 15]
target = 9
result = find_two_numbers(array, target)
if result is not None:
print(f"找到了两个数:{result[0]} 和 {result[1]},它们的和为 {target},且积也是 {result[0] * result[1]}")
else:
print("没有找到满足条件的数对。")
阅读全文