• 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. }

  • 相关阅读:
    如何在Mac上启用蓝牙,这里提供几个方法
    【经典算法学习-排序篇】顺序查找 - 作业讲解
    【JDBC篇】preparedStatement功能介绍
    初学Nodejs(2):Buffer缓冲区
    Android 10.0后创建文件
    mysql故障mysqld got signal 6,由于异常断电或者系统异常重启时MySQL没有正常退出导致MySQL无法启动
    Android 顶部标签栏及内容列表的设计与实现
    关于嵌入式人工智能?
    Mac实现Gitlab CICD
    IT面试参考
  • 原文地址:https://blog.csdn.net/tsb2416443_/article/details/132648305