Upgrading Technology(2019牛客暑期多校训练营(第六场)J,预处理 + 枚举)

本文主要是介绍Upgrading Technology(2019牛客暑期多校训练营(第六场)J,预处理 + 枚举),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.题目链接:

Upgrading Technology

二.题目大意:

有 n 件物品,每个物品都有 m 个等级.

当物品 i 从等级 j - 1 升级到时 j 时,需花费 c[i][j].

当所有物品都超过 j 级时,将会获得 d[j].

-10^{9} \leq c[i][j], d[j] \leq 10^{9}

三.分析:

枚举最低等级,根据贪心的原则,第 i 件物品应取大于等于 j 等级的最大收益.

但由于最低等级为 j,所以应该减去最低的收益.

ps:不要忘记最低等级为 0 的情况.

四.代码实现:

#include <set>
#include <map>
#include <ctime>
#include <queue>
#include <cmath>
#include <stack>
#include <bitset>
#include <vector>
#include <cstdio>
#include <sstream>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#define eps 1e-8
#define lc k * 2
#define rc k * 2 + 1
#define pi acos(-1.0)
#define ll long long int
using namespace std;const int M = (int)1e3;
const ll mod = (ll)1e9 + 7;
const ll inf = 0x3f3f3f3f3f3f3f3f;ll ans, d, x, add;
ll sum[M + 5][M + 5], sum_max[M + 5][M + 5];/**
1
4 3
-1  -2  -0
-3  0  0
1  -1  1
3  -4  -1
-1 -1 28
**/int main()
{int T;scanf("%d", &T);for(int ca = 1; ca <= T; ++ca){int n, m;scanf("%d %d", &n, &m);for(int i = 1; i <= n; ++i){for(int j = 1; j <= m; ++j){scanf("%lld", &x);sum[i][j] = sum[i][j - 1] - x;}sum_max[i][m + 1] = -inf;for(int j = m; j >= 0; --j)sum_max[i][j] = max(sum_max[i][j + 1], sum[i][j]);}ans = d = 0;for(int i = 0; i <= m; ++i){add = inf;for(int j = 1; j <= n; ++j)add = min(add, sum_max[j][i] - sum[j][i]);add = -add;for(int j = 1; j <= n; ++j)add += sum_max[j][i];if(i){scanf("%lld", &x);d += x;}ans = max(ans, add + d);}printf("Case #%d: %lld\n", ca, ans);}return 0;
}

 

这篇关于Upgrading Technology(2019牛客暑期多校训练营(第六场)J,预处理 + 枚举)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/861671

相关文章

C#实现获得某个枚举的所有名称

《C#实现获得某个枚举的所有名称》这篇文章主要为大家详细介绍了C#如何实现获得某个枚举的所有名称,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... C#中获得某个枚举的所有名称using System;using System.Collections.Generic;usi

Java 枚举的常用技巧汇总

《Java枚举的常用技巧汇总》在Java中,枚举类型是一种特殊的数据类型,允许定义一组固定的常量,默认情况下,toString方法返回枚举常量的名称,本文提供了一个完整的代码示例,展示了如何在Jav... 目录一、枚举的基本概念1. 什么是枚举?2. 基本枚举示例3. 枚举的优势二、枚举的高级用法1. 枚举

Rust中的Option枚举快速入门教程

《Rust中的Option枚举快速入门教程》Rust中的Option枚举用于表示可能不存在的值,提供了多种方法来处理这些值,避免了空指针异常,文章介绍了Option的定义、常见方法、使用场景以及注意事... 目录引言Option介绍Option的常见方法Option使用场景场景一:函数返回可能不存在的值场景

hdu 2489 (dfs枚举 + prim)

题意: 对于一棵顶点和边都有权值的树,使用下面的等式来计算Ratio 给定一个n 个顶点的完全图及它所有顶点和边的权值,找到一个该图含有m 个顶点的子图,并且让这个子图的Ratio 值在所有m 个顶点的树中最小。 解析: 因为数据量不大,先用dfs枚举搭配出m个子节点,算出点和,然后套个prim算出边和,每次比较大小即可。 dfs没有写好,A的老泪纵横。 错在把index在d

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

hdu 6198 dfs枚举找规律+矩阵乘法

number number number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description We define a sequence  F : ⋅   F0=0,F1=1 ; ⋅   Fn=Fn

【Rust练习】12.枚举

练习题来自:https://practice-zh.course.rs/compound-types/enum.html 1 // 修复错误enum Number {Zero,One,Two,}enum Number1 {Zero = 0,One,Two,}// C语言风格的枚举定义enum Number2 {Zero = 0.0,One = 1.0,Two = 2.0,}fn m

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA

暑期学习总结

iOS学习 前言无限轮播图换头像网络请求按钮的configuration属性总结 前言 经过暑期培训,完成了五个项目的仿写,在项目中将零散的内容经过实践学习,有了不少收获,因此来总结一下比较重要的内容。 无限轮播图 这是写项目的第一个难点,在很多项目中都有使用,越写越熟练。 原理为制造两个假页,在首和尾分别制作最后一页和第一页的假页,当移动到假页时,使用取消动画的方式跳到