C语言题目。在线性代数、计算几何中,向量点积是一种十分重要的运算。给定两个n维向量a=(a1,a2,...,an)和b=(b1,b2,...,bn),求点积a·b=a1b1+a2b2+...+anbn。
时间: 2024-09-11 21:12:56 浏览: 66
在C语言中,计算两个n维向量的点积通常涉及到对数组元素的逐个乘法和累加操作。这里是一个简单的函数示例,它接受两个整型数组作为输入,并返回它们的点积:
```c
#include <stdio.h>
int dot_product(int a[], int b[], int n) {
int result = 0;
for (int i = 0; i < n; i++) {
result += a[i] * b[i];
}
return result;
}
int main() {
int a[] = {a1, a2, ..., an}; // 你需要提供具体的向量元素
int b[] = {b1, b2, ..., bn};
int n = sizeof(a) / sizeof(a[0]);
int product = dot_product(a, b, n);
printf("The dot product of vectors %s and %s is %d.\n", a, b, product);
return 0;
}
```
在这个例子中,`dot_product`函数遍历数组`a`和`b`,每次将对应的元素相乘并累加到`result`上。注意,你需要替换`a1`, `a2`, ... 和 `an`,`b1`, `b2`, ... , `bn`为你实际的向量值。
阅读全文