当前位置: 首页 > news >正文

HJ70 矩阵乘法计算量估算

Powered by:NEFU AB-IN

Link

文章目录

  • HJ70 矩阵乘法计算量估算
    • 题意
    • 思路
    • 代码

HJ70 矩阵乘法计算量估算

  • 题意

    矩阵乘法的运算量与矩阵乘法的顺序强相关。
    例如:
    A是一个50×10的矩阵,B是10×20的矩阵,C是20×5的矩阵
    计算ABC有两种顺序:((AB)C)或者(A(BC)),前者需要计算15000次乘法,后者只需要3500次。
    编写程序计算不同的计算顺序需要进行的乘法次数。

  • 思路

    遇到括号问题,先想到用解决

    • 当遇到左括号,不用管
    • 当遇到右括号,根据题意,将数值弹出
    • 当遇到数值,压入栈即可
  • 代码

    #include <bits/stdc++.h>
    #include <stack>
    #include <unordered_map>
    using namespace std;
    #define int long long
    #undef int#define SZ(X) ((int)(X).size())
    #define ALL(X) (X).begin(), (X).end()
    #define IOS                                                                                                            \ios::sync_with_stdio(false);                                                                                       \cin.tie(nullptr);                                                                                                  \cout.tie(nullptr)
    #define DEBUG(X) cout << #X << ": " << X << '\n'
    typedef pair<int, int> PII;const int N = 1e5 + 10, INF = 0x3f3f3f3f;int dp[N];signed main()
    {// freopen("Tests/input_1.txt", "r", stdin);IOS;int n;cin >> n;unordered_map<char, PII> mp;char A = 'A';for (int i = 1; i <= n; ++i){int x, y;cin >> x >> y;mp[A] = {x, y};A = A + 1;}int ans = 0;string s;cin >> s;stack<PII> st;for (auto i : s){if (i == '(')continue;else if (i == ')'){auto a = st.top();st.pop();auto b = st.top();st.pop();ans += a.first * a.second * b.first;st.push({b.first, a.second});}else{st.push({mp[i].first, mp[i].second});}}cout << ans;return 0;
    }
    
http://www.lryc.cn/news/160713.html

相关文章:

  • Doris数据库使用记录
  • 华为OD机试真题【篮球比赛】
  • sublime text 格式化json快捷键配置
  • Spring Cloud 面试题总结
  • 如何实现24/7客户服务自动化?
  • 2022年12月 C/C++(六级)真题解析#中国电子学会#全国青少年软件编程等级考试
  • 【Spring Cloud系列】 雪花算法原理及实现
  • Postgresql 阿里云部署排雷
  • l8-d10 TCP协议是如何实现可靠传输的
  • 9月9日扒面经
  • 项目实战:ES的增加数据和查询数据
  • vs code调试rust乱码问题解决方案
  • 大数据课程K22——Spark的SparkSQL的API调用
  • 数据结构学习系列之顺序表的两种删除方式
  • 机器学习笔记之最优化理论与方法(七)无约束优化问题——常用求解方法(上)
  • ES-索引管理
  • linux中常用shell脚本整理
  • 介绍PHP
  • selenium+find_elements用法
  • 1DM+下载器_11.2.1魔改增强版下载
  • vue3:3、项目目录和关键文件
  • ChatGPT实战与私有化大模型落地
  • 10分钟从实现和使用场景聊聊并发包下的阻塞队列
  • Python入门学习13(面向对象)
  • 哈工大计算机网络课程网络安全基本原理之:身份认证
  • 海外代购系统/代购网站怎么搭建
  • go-micro
  • 安装GPU驱动,CUDA Toolkit和配置与CUDA对应的Pytorch
  • JavaScript单例模式
  • centos下安装jenkins.war