• CSP认证202305-2矩阵运算(c++)


    题目:

    样例输入:

    1. 3 2
    2. 1 2
    3. 3 4
    4. 5 6
    5. 10 10
    6. -20 -20
    7. 30 30
    8. 6 5
    9. 4 3
    10. 2 1
    11. 4 0 -5

     样例输出:

    1. 480 240
    2. 0 0
    3. -2200 -1100

     子任务:

    70 %的测试数据满足:n≤100 且 d≤10;输入矩阵、向量中的元素均为整数,且绝对值均不超过 30。

    全部的测试数据满足:n≤1e4 且 d≤20;输入矩阵、向量中的元素均为整数,且绝对值均不超过 1000。

    提示:

    请谨慎评估矩阵乘法运算后的数值范围,并使用适当数据类型存储矩阵中的整数。

    分析:

    如果按照题目给出的顺序计算:

    首先一个n行d列的矩阵与d行n列的矩阵相乘得到一个n行n列的矩阵,计算n*n*d次,n和d均取最大值,即2e9次。一般1e9就有可能超时了。然后该矩阵的每一行与对应的Wi相乘,还是一个n行n列的矩阵,用时n*n次。最后与n*n矩阵与n*d的矩阵相乘,用时n*n*d次。所以按照这个顺序肯定是过不了的。

    优化:

    d*n 与 n *d 相乘 得到 d*d 的矩阵,用时d*d*n。n*d 与 d*d的矩阵相乘,用时 n*d*d。最后一步用时n*d。按照这样的顺序就能过了。

     代码:

    1. #include
    2. #include
    3. using namespace std;
    4. #define int long long
    5. const int N = 1e4 + 5, D = 25;
    6. int q[N][D], k[N][D], V[N][D], w[N], ans[N][D], tsb[D][D];
    7. int n, d;
    8. signed main() {
    9. ios::sync_with_stdio(0);
    10. cin.tie(0); cout.tie(0);
    11. cin >> n >> d;
    12. for (int i = 1; i <= n; i++) {
    13. for (int j = 1; j <= d; j++) {
    14. cin >> q[i][j];
    15. }
    16. }
    17. for (int i = 1; i <= n; i++) {
    18. for (int j = 1; j <= d; j++) {
    19. cin >> k[i][j];
    20. }
    21. }
    22. for (int i = 1; i <= n; i++) {
    23. for (int j = 1; j <= d; j++) {
    24. cin >> V[i][j];
    25. }
    26. }
    27. for (int i = 1; i <= n; i++) {
    28. cin >> w[i];
    29. }
    30. for (int i = d; i >= 1; i--) {
    31. for (int j = 1; j <= d; j++) {
    32. int num = 0;
    33. int u = 1, v = 1;
    34. while (u <= n && v <= n) {
    35. num += k[u][i] * V[v][j];
    36. u++, v++;
    37. }
    38. //cout << num << " ";
    39. tsb[i][j] = num;
    40. }
    41. //cout << "\n";
    42. }
    43. for (int i = 1; i <= n; i++) {
    44. for (int j = 1; j <= d; j++) {
    45. int u = 1, v = 1;
    46. while (u <= d && v <= d) {
    47. ans[i][j] += q[i][u] * tsb[v][j];
    48. u++, v++;
    49. }
    50. ans[i][j] *= w[i];
    51. cout << ans[i][j] << " ";
    52. }
    53. cout << "\n";
    54. }
    55. return 0;
    56. }

  • 相关阅读:
    Transform+ASM插桩系列(3)——Transform+ASM的实战
    appium+jenkins实例构建
    android MediaStore.ACTION_IMAGE_CAPTURE 调用照相机返回图片太小问题解决方法
    k8s部署rook ceph
    linux软链接的创建、删除和更新
    Goland Cannot use ‘err‘ (type error) as the type any
    【最接地气的KMP算法】带着问题思考,带你彻底搞懂KMP算法中难以理解的点!
    spring Controller参数
    PyPy+Cython对Python进行加速,以及乱码问题
    【C语言】栈的实现
  • 原文地址:https://blog.csdn.net/tsb2416443_/article/details/132648305