#include #include using namespace std;

int main() { int n, m; cin >> n >> m; vector<vector> A(n, vector(m)); for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { cin >> A[i][j]; } } vector b(m); for (int i = 0; i < m; i++) { cin >> b[i]; } vector c(n); for (int i = 0; i < n; i++) { int sumA = 0; for (int k = 0; k < m; k++) { sumA += A[i][k] * b[k]; } c[i] = sumA; } for (int i = 0; i < n; i++) { cout << c[i] << endl; } return 0; }

根据你提供的代码,你的目标是计算矩阵 A 和向量 b 的乘积 Ab,并按要求输出结果。

然而,你的代码存在一些问题:

  1. 向量 'b' 的维度应为 m×1,但你的代码中创建了 m×1 的二维向量。应该将 'vector<vector>b(m, vector(1));' 改为 'vector b(m);'。

  2. 在计算乘积 Ab 的过程中,你的代码有以下问题:

    • 你错误地使用了 'c[i][1]' 作为向量 c 的元素索引,应该改为 'c[i][0]'。
    • 在计算 'sumA' 时,你应该使用 'A[i][k] * b[k]',而不是 'A[i][k]',因为你想计算每个元素的乘积。
    • 在计算完每一行的 'sumA' 后,你应该将其赋值给 'c[i][0]',而不是 'c[i][1]'。

以下是修正后的代码:

#include <iostream>
#include <vector>
using namespace std;

int main()
{
    int n, m;
    cin >> n >> m;
    vector<vector<int>> A(n, vector<int>(m));
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            cin >> A[i][j];
        }
    }
    vector<int> b(m);
    for (int i = 0; i < m; i++)
    {
        cin >> b[i];
    }
    vector<int> c(n);
    for (int i = 0; i < n; i++)
    {
        int sumA = 0;
        for (int k = 0; k < m; k++)
        {
            sumA += A[i][k] * b[k];
        }
        c[i] = sumA;
    }
    for (int i = 0; i < n; i++)
    {
        cout << c[i] << endl;
    }
    return 0;
}

请确保输入的矩阵 A 和向量 b 的元素符合要求,并适当验证输入,以满足题目要求。

C++ 代码优化:矩阵与向量乘积 Ab 的计算

原文地址: https://www.cveoy.top/t/topic/jvu 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录