• 2016级算法第三次上机-B.Bamboo和巧克力工厂


    B Bamboo和巧克力工厂

    分析

    三条流水线的问题,依然是动态规划,但是涉及的切换种类比较多。比较易于拓展到n条流水线的方式是三层循环,外层是第k个机器手,里面两层代表可切换的流水线
    核心dp语句:cost[i][k] = min(cost[i][k], cost[j][k-1]+t[j][i]+p[i][k])
    也可以在A题的基础上详细的列出所有可能的路线切割情况然后找到最小值。

    注意本题与A题中t的含义不同。

    上机时给出的伪代码

    //数组从0开始    
    const int maxx= 510;
     p[3][maxx];
     t[3][3];
     cost[3][maxx];//dp主体    
    N=2;  M为输入值
    void resolve(int N,int M)
    {
        初始化cost为无穷大
        三条流水线的初始值为对应的P值:
        cost[i][0] = p[i][0];
        for k=1:M-1
            for i=0:2
                for j = 0:2
                cost[i][k]  =  min(cost[i][k], cost[j][k-1]+t[j][i]+p[i][k]);
                end
             end
         end
      
        找出三条线路中在最后一个机器手时总用时的最小值即为所求
    }
    

    代码

    const int maxx= 510;
    int p[3][maxx];
    int t[3][3];
    int cost[3][maxx];
    const int MAX = (1<<30);
    void Resolve(int n,int m)
    {
        int i,j;
        for(i= 0; i<n; i++)
            for(j =0; j<m; j++)
                cost[i][j]  = MAX ;
        for(int i= 0; i<n; i++)
            cost[i][0] = p[i][0];
    
        for(int k = 1; k<m; k++)
            for(int i = 0; i<n; i++)
                for(int j = 0; j<n; j++)
                {
                    cost[i][k]  =  min(cost[i][k], cost[j][k-1]+t[j][i]+p[i][k]);
                }
        int ans = 500000000;
        for( i  =0; i<n; i++)
        {
            if(cost[i][m-1]<ans)
                ans = cost[i][m-1];
        }
        printf("%d
    ",ans);
    }
    int main()
    {
        int m;
        while(scanf("%d",&m)!=EOF)
        {
            int i,j;
            for(i = 0; i<3; i++)
                for( j = 0; j<m; j++)
                    scanf("%d",&p[i][j]);
            for(i= 0; i<3; i++)
                for( j = 0; j<3; j++)
                    scanf("%d",&t[i][j]);
            Resolve(3,m);
        }
    }
    
  • 相关阅读:
    Appuim学习路-Appuim介绍
    mac下将根目录/更改组到普通用户,导致sudo不能用
    shell获取函数的返回值
    grep匹配字符串出现的次数
    python实现测试报告的bug统计
    ios开发者账号、证书相关内容
    java基础三 [深入多态,接口和多态](阅读Head First Java记录)
    java基础二(阅读Head First Java记录)
    mac下搭建appium
    窗口管理器 Openbox 入门指南
  • 原文地址:https://www.cnblogs.com/AlvinZH/p/7977874.html
Copyright © 2020-2023  润新知