博客
关于我
AtCoder Beginner Contest 100 D - Patisserie ABC[思维]
阅读量:535 次
发布时间:2019-03-08

本文共 994 字,大约阅读时间需要 3 分钟。

题意:n个物品,每个物品有三个属性a,b,c(可能正,可能负) .现在取m个,使得|sigma a| + |sigma b| + |sigma c| 最大化

思路:考虑绝对值里的符号.每个绝对值里的符号取值无非有2种情况. 趋向   极负/极正  .那么就有2*2*2=8种符号可能.每次排序nlogn,按i*a+j*b+c*k排序.8种情况必有一种情况满足要求

#include
#define PI acos(-1.0)#define pb push_back#define F first#define S secondusing namespace std;typedef long long ll;const int N=1e5+5;//ll a[N],sum[N];struct node{ ll a,b,c;}p[N];int n,m,i,j,k;bool cmp(node x,node y){ return x.a*i+x.b*j+x.c*k>y.a*i+y.b*j+y.c*k;}int main(void){ ios::sync_with_stdio(false); cin.tie(0);cout.tie(0); cin >> n>>m; ll ans=0; for(int i=1;i<=n;i++) cin >>p[i].a>>p[i].b >>p[i].c; for( i=-1;i<=1;i+=2){// i,j,k分别代表绝对值里的符号趋向 for( j=-1;j<=1;j+=2){ for( k=-1;k<=1;k+=2){ sort(p+1,p+1+n,cmp); ll t[4]={0}; for(int te=1;te<=m;te++) t[1]+=p[te].a,t[2]+=p[te].b,t[3]+=p[te].c; ans=max(ans,t[1]*i+t[2]*j+t[3]*k); } } } cout << ans << endl; return 0;}

转载地址:http://xykiz.baihongyu.com/

你可能感兴趣的文章
mysql列转行函数是什么
查看>>
mysql创建函数报错_mysql在创建存储函数时报错
查看>>
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
MySQL删除数据几种情况以及是否释放磁盘空间【转】
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>
mysql加强(6)~子查询简单介绍、子查询分类
查看>>
mysql加强(7)~事务、事务并发、解决事务并发的方法
查看>>