UVA 348 Optimal Array Multiplication Sequence (区间DP)

举报
Linux猿 发表于 2021/08/05 00:30:14 2021/08/05
【摘要】 题目链接~~> 做题感悟:这题上来一看就是矩阵连成,就是输出的时候有点不好输出。 解题思路:矩阵连乘:状态方程 ->   dp[ i ][ j ] = min{ dp[ i ][ k ] +dp[ k+1 ][ j ] + p[ i ] * p[ k ]*p[ j ] } 代码: #include<stdio.h>#include&...

题目链接~~>

做题感悟:这题上来一看就是矩阵连成,就是输出的时候有点不好输出。

解题思路:矩阵连乘:状态方程 ->   dp[ i ][ j ] = min{ dp[ i ][ k ] +dp[ k+1 ][ j ] + p[ i ] * p[ k ]*p[ j ] }

代码:


  
  1. #include<stdio.h>
  2. #include<vector>
  3. #include<queue>
  4. #include<string.h>
  5. #include<stdlib.h>
  6. #include<string.h>
  7. #include<algorithm>
  8. #include<iostream>
  9. #define INT __int64
  10. const int INF = 99999999 ;
  11. using namespace std ;
  12. const int MX = 100 + 10 ;
  13. int n ;
  14. int m[MX][MX],s[MX][MX],p[MX] ;
  15. void Matrix()
  16. {
  17. for(int i=1 ;i<=n ;i++)
  18. {
  19. m[i][i]=0 ;
  20. s[i][i]=0 ;
  21. }
  22. for(int r=2 ;r<=n ;r++)
  23. for(int i=1 ;i<=n-r+1 ;i++)
  24. {
  25. int j=i+r-1 ;
  26. m[i][j]=m[i+1][j]+p[i-1]*p[i]*p[j] ;
  27. s[i][j]=i ;
  28. for(int k=i+1 ;k<j ;k++)
  29. {
  30. int temp=m[i][k]+m[k+1][j]+p[i-1]*p[k]*p[j] ;
  31. if(temp<m[i][j])
  32. {
  33. m[i][j]=temp ;
  34. s[i][j]=k ;
  35. }
  36. }
  37. }
  38. }
  39. void print(int i,int j)
  40. {
  41. if(i==j)
  42. {
  43. cout<<"A"<<i ;
  44. return ;
  45. }
  46. cout<<"(" ;
  47. print(i,s[i][j]) ;
  48. cout<<" x " ;
  49. print(s[i][j]+1,j) ;
  50. cout<<")" ;
  51. }
  52. int main()
  53. {
  54. int x,cse=1 ;
  55. while(scanf("%d",&n),n)
  56. {
  57. scanf("%d",&p[0]) ;
  58. for(int i=1 ;i<=n ;i++)
  59. {
  60. scanf("%d",&p[i]) ;
  61. if(i!=n)
  62. scanf("%d",&x) ;
  63. }
  64. Matrix() ;
  65. cout<<"Case "<<cse++<<": " ;
  66. print(1,n) ;
  67. cout<<endl ;
  68. }
  69. return 0 ;
  70. }


文章来源: blog.csdn.net,作者:Linux猿,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/nyist_zxp/article/details/37873173

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。