算法实验四-动态规划

1.多段图中的最短路径问题
【问题描述】
建立一个从源点S到终点T的多段图,设计一个动态规划算法求出从S到T的最短路径值,并输出相应的最短路径。

#include<iostream>
#include<cmath>
#include<string.h>
#include<stdio.h>
using namespace std;
int  dp[1222222],alone[1222222],a[1222222];
int main()
{
   int i,j,n,m;
   while(~scanf("%d",&m))
   {
       scanf("%d",&n);
       memset(dp,0,sizeof(dp));
       memset(alone ,0,sizeof(alone));
       for(i=1;i<=n;i++)scanf("%d",&a[i]);
       int tmax;
       for(i=1;i<=m;i++)//分i段
       {
           tmax=-(1<<30);

           for(j=i;j<=n;j++)
           {
               dp[j]=max(dp[j-1],alone[j-1])+a[j];


               printf("%2d %2d %2d\\n",a[j],alone[j-1],dp[j]);
               if(j>i)alone[j-1]=tmax;

               if(tmax<dp[j])tmax=dp[j];

           }

       }
       printf("%d\\n",tmax);
   }
   return 0;
} ``` 





2.有向无环图中的最短路径问题
【问题描述】
建立一个从源点S到终点E的有向无环图,设计一个动态规划算法求出从S到E的最短路径值,并输出相应的最短路径。

include <iostream>

include <limits.h>

using namespace std;

void Init_Graph(int N,int **S)
{
int i,j;
cout<<"输入边的长度:输入1 2 4 表示点1 与 2的边的长度为 4:首数字为0表示结束输入"<<endl;
cin>>i;
while(i!=0)
{
cin>>j;
cin>>S[i][j];
cin>>i;
}
}

void DP(int N,int **S,int *dist,int *from)
{
int i,j;
for(j=0;j<N+1;j++)
{
if(S[1][j]<INT_MAX)
{
dist[j]=S[1][j];
from[j]=1;
}
}

for(j=2;j<N+1;j++)
{
    for(i=2;i<j;i++)
    {
        if(S[i][j]<INT_MAX)
        {
            if(dist[i]+S[i][j]<dist[j])
            {
                dist[j]=dist[i]+S[i][j];
                from[j]=i;
            }
        }
    }
}
cout<<"最短路径为:";
i=6;
cout<<N<<"  "<<from[i]<<"  ";
i=from[i];
while(i!=1)
{
    cout<<from[i]<<"  ";
    i=from[i];
}
cout<<"\\n";
cout<<"最短距离为:"<<dist[N]<<endl;

}

int main()
{
int N;
int S,dist,from;
int i,j;
cout<<"输入点的个数:";
cin>>N;

S=new int*[N+1];
for(i=0;i<N+1;i++)
{
    S[i]=new int[N+1];
    for(j=0;j<N+1;j++)
    {
        S[i][j]=INT_MAX;
    }
}
dist=new int[N+1];
for(i=0;i<N+1;i++)
{
    dist[i]=INT_MAX;
}
from=new int[N+1];
for(i=0;i<N+1;i++)
{
    from[i]=0;
}

Init_Graph(N,S);
DP(N,S,dist,from);

for(i=0;i<N+1;i++)
{
    delete []S[i];
}
delete []S;
delete []dist;
delete []from;
return 0;

}


3.最长递增子序列问题
【问题描述】
给定一个整数数组,设计一个动态规划算法求出该数组中的最长递增子序列。


4.矩阵连乘问题
【问题描述】
给定n个矩阵{A1,A2,…,An},其中AiAi+1是可乘的,i=1,2,…,n-1,考察这n个矩阵的连乘积A1A2…An,设计一个动态规划算法,求出这个矩阵连乘积问题的最优计算顺序。
实现要求:随机生成n个合法的可连乘的矩阵,以完全加括号的方式输出其最优计算顺序。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 动态规划(Dynamic Programming) 本文包括: 动态规划定义 状态转移方程 动态规划算法步骤 最长...
    廖少少阅读 8,870评论 0 18
  • 本文翻译自TopCoder上的一篇文章: Dynamic Programming: From novice to ...
    扎Zn了老Fe阅读 5,912评论 0 3
  • 实验一 实验目的与要求:理解分治法的基本思想和设计方法。 实验题目: 1.实现基于分治法的归并排序算法. 2.实现...
    mdbbm阅读 5,709评论 0 3
  • 在校期间要做的事(按重要性和紧迫性先后顺序排列): 1. 寻找合适的论文题目(多选择几个后与导师沟通);既重要又紧...
    lawyerxia阅读 1,544评论 0 0
  • 赠人玫瑰,手有余香 这几个月忙活着做项目,考虑到技术与时俱进,便跟风使用了dubbo来完成这个项目了,期间也是各种...
    switch_zyp阅读 4,688评论 1 3

友情链接更多精彩内容