博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
矩阵链相乘问题
阅读量:3962 次
发布时间:2019-05-24

本文共 912 字,大约阅读时间需要 3 分钟。

矩阵的乘法定义如下:设A是m×p的矩阵,B是p×n的矩阵,则A与B的乘积为m×n的矩阵,记作C=AB,其中,矩阵C中的第i行第j列元素cij可以表示为:

当多个矩阵相乘时,采用不同的计算顺序所需的乘法次数不相同。例如,A是50×10的矩阵,B是10×20的矩阵,C是20×5的矩阵, 计算ABC有两种方式:(AB)C和A(BC),前一种需要15000次乘法计算,后一种则只需3500次。
设A1,A2,…,An为矩阵序列,A​i是阶为P​i−1∗P​i的矩阵(1≤i≤n)。试确定矩阵的乘法顺序,使得计算A1A2…An过程中元素相乘的总次数最少。
输入格式:
每个输入文件为一个测试用例,每个测试用例的第一行给出一个正整数n(1≤n≤100),表示一共有n个矩阵A1,A2,…,An,第二行给出n+1个整数P0 ,P1…Pn,以空格分隔,其中1≤P​i≤100(0≤i≤n),第i个矩阵A​i是阶为P​i−1∗P​i的矩阵。
输出格式:
获得上述矩阵的乘积,所需的最少乘法次数。
输入样例:
在这里给出一组输入。例如:

530 35 15 5 10 20

输出样例:

在这里给出相应的输出。例如:

11875
#include 
using namespace std;const int MAX = 1005;int p[MAX];int m[MAX][MAX];int n;void matrix(){
int i,j,r,k; memset(m,0,sizeof(m)); for(r = 2; r<=n; r++) {
for(i = 1; i<=n-r+1; i++) {
j = i+r-1; m[i][j] = m[i+1][j]+p[i-1]*p[i]*p[j]; for(k = i+1; k
>n; for(int i=0; i
>p[i]; matrix(); cout<
<

转载地址:http://vyezi.baihongyu.com/

你可能感兴趣的文章
程序员不应该再犯的五大编程错误
查看>>
[转载][转帖]Hibernate与Sleep的区别
查看>>
Linux系统的默认编码设置
查看>>
Linux系统调用
查看>>
Linux 信号signal处理机制
查看>>
Linux 信号signal处理函数
查看>>
perror简介
查看>>
linux的system () 函数详解
查看>>
在shell脚本的第一行中,必须写#!/bin/bash
查看>>
一句话##错误 'ASP 0116' 丢失脚本关闭分隔符
查看>>
文件上传漏洞之.htaccess
查看>>
常见网络安全设备默认口令
查看>>
VirtualBox虚拟机网络配置
查看>>
oracle vm virtualbox虚拟机下,CentOS7系统网络配置
查看>>
解决Linux CentOS中cp -f 复制强制覆盖的命令无效的方法
查看>>
wdcpv3升级到v3.2后,多PHP版本共存的安装方法
查看>>
PHP统计当前网站的访问人数,访问信息,被多少次访问。
查看>>
Windows10远程报错CredSSP加密oracle修正
查看>>
Windows server 2016 设置多用户登陆
查看>>
偶然发现的面包屑
查看>>