zoukankan      html  css  js  c++  java
  • [POJ 3666] Making the Grade

    [题目链接]

             http://poj.org/problem?id=3666

    [算法]

           离散化 + dp

    [代码] 

              

    #include <algorithm>  
    #include <bitset>  
    #include <cctype>  
    #include <cerrno>  
    #include <clocale>  
    #include <cmath>  
    #include <complex>  
    #include <cstdio>  
    #include <cstdlib>  
    #include <cstring>  
    #include <ctime>  
    #include <deque>  
    #include <exception>  
    #include <fstream>  
    #include <functional>  
    #include <limits>  
    #include <list>  
    #include <map>  
    #include <iomanip>  
    #include <ios>  
    #include <iosfwd>  
    #include <iostream>  
    #include <istream>  
    #include <ostream>  
    #include <queue>  
    #include <set>  
    #include <sstream>  
    #include <stdexcept>  
    #include <streambuf>  
    #include <string>  
    #include <utility>  
    #include <vector>  
    #include <cwchar>  
    #include <cwctype>  
    #include <stack>  
    #include <limits.h> 
    using namespace std;
    #define MAXN 2010
    typedef long long ll;
    const ll INF = 1e15;
    
    int i,n,len;
    ll a[MAXN],tmp[MAXN];
    ll ans;
    ll dp[MAXN][MAXN];
    
    ll myabs(ll x)
    {
        return x < 0 ? -x : x;
    }
    inline ll dp1()
    {
        int i,j;
        ll mn = INF,ret = INF;
        for (i = 1; i <= n; i++)
        {
            for (j = 1; j <= len; j++)
            {
                dp[i][j] = INF;
            }
        }
        for (i = 1; i <= len; i++) dp[1][i] = myabs(a[1] - tmp[i]);
        for (i = 2; i <= n; i++)
        {
            mn = INF;
            for (j = 1; j <= len; j++)
            {
                mn = min(mn,dp[i-1][j]);
                dp[i][j] = mn + myabs(a[i] - tmp[j]);
            }    
        }
        for (i = 1; i <= len; i++) ret = min(ret,dp[n][i]);
        return ret;
    }
    inline ll dp2()
    {
        int i,j;
        ll mn = INF,ret = INF;
        for (i = 1; i <= n; i++)
        {
            for (j = 1; j <= len; j++)
            {
                dp[i][j] = INF;
            }
        }    
        for (i = 1; i <= len; i++) dp[1][i] = myabs(a[1] - tmp[i]);
        for (i = 2; i <= n; i++)
        {
            mn = INF;
            for (j = len; j >= 1; j--)
            {
                mn = min(mn,dp[i-1][j]);
                dp[i][j] = mn + myabs(a[i] - tmp[j]);
            }
        }
        for (i = 1; i <= len; i++) ret = min(ret,dp[n][i]);
        return ret;
    }
    
    int main()
    {
        
        scanf("%d",&n);
        for (i = 1; i <= n; i++) 
        {
            scanf("%lld",&a[i]);
            tmp[i] = a[i];
        }
        sort(tmp+1,tmp+n+1);
        len = unique(tmp+1,tmp+n+1) - tmp - 1;
        ans = min(dp1(),dp2());
        printf("%lld
    ",ans);
    
        return 0;
    }
  • 相关阅读:
    node.js前后台交互示例 -- 使用node.js实现用户注册功能
    window对象
    ajax模仿iframe
    判断浏览器是否支持某些新属性---placeholder兼容问题解决
    jQuery简单tab按钮切换
    js函数的解析与执行过程
    js全局的解析与执行过程
    OKR解读
    《富爸爸穷爸爸》读书笔记【2020207-19】
    《金字塔原理》读书笔记【2020111-30】一读+二读
  • 原文地址:https://www.cnblogs.com/evenbao/p/9324790.html
Copyright © 2011-2022 走看看