我正在嘗試編寫計算兩個給定向量的點積的C++程序。在向量a和b中,只有非零元素將被存儲到結構數組中。我想我無法正確地將矢量讀入結構數組中。 請指教。 預先感謝您讀取非零向量成員到陣列和輸出點產品
#include <iostream>
#include <vector>
using namespace std;
const int n=10; /* vector size limit */
struct element {
int x; /* original index of non-zero array element */
int val ; /* integer non-zero value at index x */
};
element row[n];
element col[n];
int i;
vector<int> a={0,0,7,0,5,0,0,8,0,4,-1};
vector<int> b={0,0,0,5,6,0,0,0,0,5,-1};
void generate_row_and_col()
{
for (i=0; i<=n; i++)
{
if(a[i]=!0)
{
row[i].x=i;
row[i].val=a[i];
}
}
for (i=0; i<=n; i++)
{
if(b[i]!=0)
{
col[i].x=i;
col[i].val=b[i];
}
}
}
int dotproduct()
{
/* calculate the dot product of row and col output the result*/
int i=0;
int j=0;
int product=0;
while(row[i].x!=-1 && col[j].x!=-1)
{
if(row[i].x == col[j].x)
{
product=product+row[i].val*col[j].val;
i++;
j++;
}
else if(row[i].x<col[j].x)
{
i++;
}
else
{
j++;
}
}
return product;
}
int main()
{
generate_row_and_col() ;
int r;
r=dotproduct();
cout<<"result="<<r<<endl;
return 0;
}
*我試圖寫C++是計算給定的兩個向量的點積程序* - [性病:: inner_product(HTTP ://en.cppreference.com/w/cpp/algorithm/inner_product)完成這項工作。實際上,這是一個不使用無關數組的3行程序,這包括通過簡單調用'std :: stable_partition'去除零元素。 – PaulMcKenzie