UVa 442 ------ Matrix Chain Multiplication

原创 2015年11月20日 15:02:41

题目: UVa 442


题意:输入n个矩阵的维度和一些矩阵链乘表达式,输出乘法的步数。若乘法无法进行,输出error。

    如A m*n, B n*p, 那么A*B的步数为m*n*p;若A的列数不等于B的行数,乘法无法进行


思路:若遇到字母,则将相应矩阵入栈;

   若遇到右括号,则取栈顶的两个元素相乘(注意两个矩阵的顺序),累加步数,并将相乘的结果入栈


代码:

/*
	UVa 442 矩阵链乘
*/
#include <cstdio>
#include <stack>
#include <iostream>
#include <string>
using namespace std;

struct Mat{
	int r, c;
	Mat(int a = 0, int b = 0)
		:r(a), c(b){}
}m[26];

stack<Mat> s;

int main()
{
	int n;
	scanf("%d", &n);
	for (int i = 0; i < n; ++i){
		//n个矩阵的存储
		string name;
		cin >> name;
		int k = name[0] - 'A';
		cin >> m[k].r >> m[k].c;
	}

	string tmp;
	while (cin >> tmp){
		int len = tmp.length();
		bool error = false;
		int ans = 0;
		for (int i = 0; i < len; ++i){
			if (isalpha(tmp[i])) //字母,则入栈
				s.push(m[tmp[i] - 'A']);
			else if (tmp[i] == ')'){ 
				//遇到又括号,k2,k1依次出栈,累加上步数,并将矩阵相乘结果入栈
				Mat k2 = s.top(); s.pop();
				Mat k1 = s.top(); s.pop();//注意后取的为k1, 运算k1*k2
				if (k1.c != k2.r){
					error = true;
					break;
				}
				else
				{
					ans += (k1.r * k1.c * k2.c);
					s.push(Mat(k1.r, k2.c));
				}
			}
		}//for(i)
		if (error){
			printf("error\n");
		}
		else{
			printf("%d\n", ans);
		}
	}//while(tmp)
	return 0;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

算法之动态规划-矩阵链相乘(matrix-chain multiplication)

Matrix-chain multiplication给定一串矩阵 A1,A2...AnA1,A2...An,计算矩阵的值:A1A2A3..AnA_1A_2A_3..A_n。对于这串矩阵序列,不同的加...
  • qq_24145735
  • qq_24145735
  • 2016年04月07日 22:38
  • 1130

【CUDA并行编程之四】矩阵相乘

前面介绍了基本的Cuda编程的相关知识,那么这一篇在此基础之上来看看GPU在处理数据计算上的高效能,我们拿矩阵相乘来作为例子。 1.CPU上执行矩阵相乘以及性能。 2.GPU上执行矩阵相乘以及性能。 ...
  • lavorange
  • lavorange
  • 2014年12月12日 23:11
  • 1998

CLRS 15.3动态规划原理

练习15.3-1、15.3-2、15.3-3、15.3-4、15.3-5、15.3-6
  • u012593447
  • u012593447
  • 2016年05月26日 08:36
  • 2278

UVA442 Matrix Chain Multiplication 矩阵运算量计算(栈的简单应用)

栈的练习,如此水题竟然做了两个小时。。。
  • hcbbt
  • hcbbt
  • 2013年07月05日 19:23
  • 1467

Matrix Chain Multiplication, UVa442

Matrix Chain Multiplication Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu ...
  • bao_libra
  • bao_libra
  • 2016年05月02日 16:55
  • 218

Matrix Chain Multiplication UVA 442(栈+表达式求值)

Suppose you have to evaluate an expression like A*B*C*D*E where A,B,C,D and E are matrices. Since ma...
  • chat_c
  • chat_c
  • 2016年02月09日 23:04
  • 230

Uva 442-Matrix Chain Multiplication (基本栈)

Suppose you have to evaluate an expression like A*B*C*D*E where A,B,C,D and E are matrices. Since ma...
  • hentaidesu
  • hentaidesu
  • 2015年12月01日 18:17
  • 155

uva442 Matrix chain multiplication(数据结构)

看错题意,以为是给出如ABCDE然后求出最少的策略使乘积次数最少,直到看了别人的代码才回过神来。 其实这道题就和括号匹配那道题差不多,用栈解决。 由于不会用stl,就直接模拟了。(本来说好要学的,...
  • abc13068938939
  • abc13068938939
  • 2016年06月28日 15:27
  • 183

UVA - 442 Matrix Chain Multiplication(栈)

Description Suppose you have to evaluate an expression like A*B*C*D*E where A,B,C,D and E are matri...
  • u013300509
  • u013300509
  • 2015年03月05日 13:27
  • 300

uva442 Matrix Chain Multiplication

UVA 442 题意:输入几个矩阵 然后输入字符串,根据输出的字符串,判断矩阵相乘所需要计算的乘法次数 思路:用栈的思想,用一个二维数组模拟栈,遇到左括号往上多一层,遇到右括号运算结果,保存...
  • u011217342
  • u011217342
  • 2013年07月09日 08:14
  • 1166
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:UVa 442 ------ Matrix Chain Multiplication
举报原因:
原因补充:

(最多只允许输入30个字)