题解 | #矩阵乘法计算量估算#

矩阵乘法计算量估算

http://www.nowcoder.com/practice/15e41630514445719a942e004edc0a5b

使用栈计算

#include <iostream>
#include <vector>
#include <stack>

using namespace std;

pair<int,int> matrix_mul(pair<int,int> a,pair<int,int> b,int& sum) {
    sum += a.first * b.second * a.second;
    
    return pair<int,int>(a.first,b.second);
}

int main() {
    
    int num;
    cin >> num;
    
    vector<pair<int,int>> matrixs;
    
    int count = num;
    while(count--) {
        int a,b;
        cin >> a >> b;
        matrixs.push_back(pair<int,int>(a,b));
    }
    
    string s;
    cin >> s;
    
    string::iterator it_start = s.begin();
    string::iterator it_end = s.end();
    
//     stack<char> s;
    stack<pair<int,int>> sp;
    
    count = 0;
    int sum=0;
    while(it_start!= it_end) {
        
        switch(*it_start) {
            case '(': 
                break;
            case ')': {
                pair<int,int> b(sp.top());
                sp.pop();
                pair<int,int> a(sp.top());
                sp.pop();
                sp.push(matrix_mul(a,b,sum));
                break;
            }
            default: 
                sp.push(matrixs[count]);
                count++;
                break;
        }
        it_start++;
    }
    
    cout << sum;
    
    return 0;
}
全部评论

相关推荐

03-12 09:57
软件测试
程序员小白条:1)确定测试,测开的方向,技术栈不能写这么少 2)课程凑数的,不是99,100分没必要写 3)实习经历这块要有突出的不是劳动性质的亮点,自己设计的什么方案,什么自动化?什么提效工具?不是一些边角料,人云亦云的东西,没吸引力 4) 校园经历纯没用 5)尽量少写减分项
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务