c语言给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。 你可以按任意顺序返回答案。
时间: 2024-10-24 19:13:11 浏览: 23
这是一个常见的编程面试题,通常被称为“两数之和”(Two Sum)问题。在C语言中,可以使用哈希表(也叫散列表)来解决这个问题,因为哈希表可以在常数时间内完成查找操作。以下是基本的解决方案:
```c
#include <stdio.h>
#include <stdbool.h>
bool foundTarget(int nums[], int n, int target) {
// 创建一个空的哈希表
int hash[10000] = {0}; // 省略数组大小,这里只是一个示例,实际需要根据nums数组的范围调整
for (int i = 0; i < n; ++i) {
// 如果目标值已经在哈希表中,直接返回这两个数的索引
if (hash[target - nums[i]] != 0)
return true;
// 否则,将当前元素添加到哈希表中
hash[nums[i]] = i;
}
// 没有找到匹配,返回false
return false;
}
// 主函数示例
int main() {
int nums[] = {2, 7, 11, 15};
int n = sizeof(nums) / sizeof(nums[0]);
int target = 9;
if (foundTarget(nums, n, target))
printf("找到了两个数,下标分别是 %d 和 %d\n", hash[target - nums[0]], hash[nums[1]]);
else
printf("未找到满足条件的两个数\n");
return 0;
}
```
在这个程序中,我们遍历数组,对于每个元素,我们在哈希表中查找目标值减去它的差值。如果找到,则说明已经找到了一对符合条件的数;如果没有找到,我们就将当前元素的值及其索引入入哈希表继续搜索。
阅读全文