描述
在线性代数、计算几何中,向量点积是一种十分重要的运算。
给定两个n维向量a=(a1,a2,...,an)和b=(b1,b2,...,bn),求点积a·b=a1b1+a2b2+...+anbn。
输入
第一行是一个整数n。1 <= n <= 1000。
第二行包含n个整数a1,a2,...,an。
第三行包含n个整数b1,b2,...,bn。
相邻整数之间用单个空格隔开。每个整数的绝对值都不超过1000。
输出
一个整数,即两个向量的点积结果。
样例输入
3 1 4 6 2 1 5
样例输出
36
#include<stdio.h>
#include<string.h> //声明头函数
int main()
{
int na[1000],nb[1000];
int i,chengji=0,n;
scanf("%d",&n);
for (i=0; i<n; i++)//表示n维Na向量
{
scanf("%d",&na[i]);
}
for (i=0; i<n; i++)//表示n维Nb向量
{
scanf("%d",&nb[i]);
}
for (i=0; i<n; i++)
{
chengji=chengji+(na[i])*(nb[i]); //chengji表示两个多维向量的向量积
}
printf("%d",chengji);
return 0;
}