zoukankan      html  css  js  c++  java
  • [JLOI2015]装备购买 (高斯消元)

    [JLOI2015]装备购买



    $ solution: $

    首先这道题的题面已经非常清晰的告诉我们这就是线性空间高斯消元的一道题(可以用某些装备来表示另一件装备,这已经不能再明显了),只是这道题要求我们求出花费最小的方案,这个我们可以直接贪心,如果有多个装备可以匹配某一个属性,那么我们选价值最小的那一个(这个可以用线性空间的定义证明),价值大的尽量往后再选(选到最后剩下一些价格大的不买即可)



    $ code: $

    #include<iostream>
    #include<cstdio>
    #include<iomanip>
    #include<algorithm>
    #include<cstring>
    #include<cstdlib>
    #include<ctime>
    #include<cmath>
    #include<vector>
    #include<queue>
    #include<map>
    #include<set>
    
    #define ll long long
    #define db double
    #define inf 0x7fffffff
    #define rg register int
    
    using namespace std;
    
    const db cha=1e-4;
    
    struct su{
        db a[505];
        int v;
        inline bool operator <(su y){return v<y.v;}
    }g[505];
    
    int n,m,tot,ans;
    int b[505];
    
    inline int qr(){
        char ch;
        while((ch=getchar())<'0'||ch>'9');
        int res=ch^48;
        while((ch=getchar())>='0'&&ch<='9')
            res=res*10+(ch^48);
        return res;
    }
    
    int main(){
        //freopen(".in","r",stdin);
        //freopen(".out","w",stdout);
        n=qr(); m=qr();
        for(rg i=1;i<=n;++i)
            for(rg j=1;j<=m;++j)
                g[i].a[j]=qr();
        for(rg i=1;i<=n;++i)
            g[i].v=qr();
        sort(g+1,g+n+1);
        for(rg i=1;i<=n;++i){
            for(rg j=1;j<=m;++j){
                if(fabs(g[i].a[j])>cha){
                    if(!b[j]){
                        b[j]=i;++tot;
                        ans+=g[i].v;
                        break;
                    }else{
                        db d=g[i].a[j]/g[b[j]].a[j];
                        for(rg k=j;k<=m;++k)
                            g[i].a[k]-=g[b[j]].a[k]*d;
                    }
                }
            }
        }printf("%d %d
    ",tot,ans);
        return 0;
    }
    
    
  • 相关阅读:
    zabbix源码安装
    利用Linux系统生成随机密码的8种方法
    Java 内存溢出(java.lang.OutOfMemoryError)的常见情况和处理方式总结
    Jenkins的参数化构建
    Jenkins中maven的作用--构建项目(三)
    Beans(dp,两次dp)
    Piggy-Bank(完全背包)
    Super Jumping! Jumping! Jumping!(dp)
    01串(dp)
    钱币兑换问题(完全背包)
  • 原文地址:https://www.cnblogs.com/812-xiao-wen/p/10680121.html
Copyright © 2011-2022 走看看