2011阿里巴巴程序设计公开赛 / 1004 Level up

2024-03-20 03:32

本文主要是介绍2011阿里巴巴程序设计公开赛 / 1004 Level up,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

比赛完玩了一天游戏(颓~)

看到有人要这题的标程,贴一下吧(除了会贴标程你还会干吗~)~

//-----------------

类型:线段树


标程:

#include <cstring>
#include <cstdio>
#include <iostream>
#include <algorithm>
#include <vector>
#include <string>
using namespace std;#define lson l , mid , rt << 1
#define rson mid + 1 , r , rt << 1 | 1
const int maxn = 11111;
const int maxk = 12;int add[maxn<<2];
int MAX[maxk][maxn<<2];
int need[maxk];
int n , K;
void pushDown(int rt) {if (add[rt]) {add[rt<<1] += add[rt];add[rt<<1|1] += add[rt];for (int i = 1 ; i <= K ; i ++) {if (MAX[i][rt<<1] != -1) MAX[i][rt<<1] += add[rt] * i;if (MAX[i][rt<<1|1] != -1) MAX[i][rt<<1|1] += add[rt] * i;}add[rt] = 0;}
}
void pushUp(int rt) {for (int i = 1 ; i <= K ; i ++) {MAX[i][rt] = max(MAX[i][rt<<1] , MAX[i][rt<<1|1]);}
}
void levelUp(int i,int l,int r,int rt) {if (l == r) {while (i < K) {if (MAX[i][rt] < need[i]) break;MAX[i+1][rt] = MAX[i][rt];MAX[i][rt] = -1;i ++;}return ;}pushDown(rt);int mid = (l + r) >> 1;if (MAX[i][rt<<1] >= need[i]) levelUp(i , lson);if (MAX[i][rt<<1|1] >= need[i]) levelUp(i , rson);pushUp(rt);
}
void update(int L,int R,int c,int l,int r,int rt) {if (L <= l && r <= R) {add[rt] += c;for (int i = K ; i >= 1 ; i --) {if (MAX[i][rt] != -1) MAX[i][rt] += c * i;if (i < K && MAX[i][rt] >= need[i]) {levelUp(i , l , r , rt);}}return ;}pushDown(rt);int mid = (l + r) >> 1;if (L <= mid) update(L , R , c , lson);if (mid < R) update(L , R , c , rson);pushUp(rt);
}
int query(int L,int R,int l,int r,int rt) {if (L <= l && r <= R) {for (int i = K ; i >= 1 ; i --) {if (MAX[i][rt] != -1) return MAX[i][rt];}}pushDown(rt);int mid = (l + r) >> 1;int ret = 0;if (L <= mid) ret = max(ret , query(L , R , lson));if (mid < R) ret = max(ret , query(L , R , rson));return ret;
}
int main() {freopen("level.in","r",stdin);freopen("level.out","w",stdout);int T , cas = 1;scanf("%d",&T);while (T --) {int Q;scanf("%d%d%d",&n,&K,&Q);for (int i = 1 ; i < K ; i ++) scanf("%d",&need[i]);memset(add , 0 , sizeof(add));memset(MAX[1] , 0 , sizeof(MAX[1]));for (int i = 2 ; i <= K ; i ++) {memset(MAX[i] , -1 , sizeof(MAX[i]));}printf("Case %d:\n" , cas ++);while (Q --) {char op[2];int a , b , c;scanf("%s",op);if (op[0] == 'W') {scanf("%d%d%d",&a,&b,&c);update(a , b , c , 1 , n , 1);} else {scanf("%d%d",&a,&b);printf("%d\n" , query(a , b , 1 , n , 1));}}puts("");}return 0;
}

这篇关于2011阿里巴巴程序设计公开赛 / 1004 Level up的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C语言程序设计(数据类型、运算符与表达式)

一、C的数据类型 C语言提供的数据类型: 二、常量和变量 2.1常量和符号常量 在程序运行过程中,其值不能被改变的量称为常量。 常量区分为不同的类型: 程序中用#define(预处理器指令)命令行定义变量将代表常量,用一个标识符代表一个常量,称为符合常量。 2.2变量 变量代表内存中具有特定属性的一个存储单元,用来存放数据,在程序运行期间,这些值是可以 改变的。 变

C语言程序设计(选择结构程序设计)

一、关系运算符和关系表达式 1.1关系运算符及其优先次序 ①<(小于) ②<=(小于或等于) ③>(大于) ④>=(大于或等于 ) ⑤==(等于) ⑥!=(不等于) 说明: 前4个优先级相同,后2个优先级相同,关系运算符的优先级低于算术运算符,关系运算符的优先级高于赋值运算符 1.2关系表达式 用关系运算符将两个表达式(可以是算术表达式或关系表达式,逻辑表达式,赋值表达式,字符

智能工厂程序设计 之1 智能工厂都本俱的方面(Facet,Aspect和Respect)即智能依赖的基底Substrate 之1

Q1、昨天分别给出了三个智能工厂的 “面face”(里面inter-face,外面outer-face和表面surface) 以及每个“面face” 各自使用的“方”(StringProcessor,CaseFilter和ModeAdapter)  。今天我们将继续说说三个智能工厂的“方面” 。在展开之前先看一下三个单词:面向facing,取向oriented,朝向toword。理解这三个词 和

MiniCPM-V: A GPT-4V Level MLLM on Your Phone

MiniCPM-V: A GPT-4V Level MLLM on Your Phone 研究背景和动机 现有的MLLM通常需要大量的参数和计算资源,限制了其在实际应用中的范围。大部分MLLM需要部署在高性能云服务器上,这种高成本和高能耗的特点,阻碍了其在移动设备、离线和隐私保护场景中的应用。 文章主要贡献: 提出了MiniCPM-V系列模型,能在移动端设备上部署的MLLM。 性能优越:

C语言程序设计 笔记代码梳理 重制版

前言 本篇以笔记为主的C语言详解,全篇一共十章内容,会持续更新基础内容,争取做到更详细。多一句没有,少一句不行!  形而上学者谓之道,形而下学者谓之器 形而上学者谓之道,形而下学者谓之器 第1章 C语言的流程 1.C程序经历的六个阶段 编辑(Edit)预处理(Preprocess)编译(Compile)汇编(Assemble)链接(Link)执行(Execute)  2.

ACM东北地区程序设计大赛

不得不说随着参赛级别的提高,题目真的是越来越难啊,不过队长真是给力啊,在我们三个共同努力之下拿下了地区赛三等奖,哈哈我们可是大一唯一一只获奖队,终于在这次比赛打败了田大神。。。大神是失手了,俺和他差距还是挺大的。。。队友陈彤马上要去服兵役了,他说这是我们送给他最好的离别礼物,希望那家伙在部队好好干,以后谁干揍我!!!东北地区赛结束后,今年已经估计没机会参加亚洲区比赛了,赶紧补高数和线数啊!!别挂了

pta-2024年秋面向对象程序设计实验一-java

文章申明:作者也为初学者,解答仅供参考,不一定是最优解; 一:7-1 sdut-sel-2 汽车超速罚款(选择结构) 答案: import java.util.Scanner;         public class Main { public static void main(String[] arg){         Scanner sc=new Scanner(System

C语言程序设计(算法的概念及其表示)

一、算法的概念 一个程序应包括两个方面的内容: 对数据的描述:数据结构 对操作的描述:算法 著名计算机科学家沃思提出一个公式: 数据结构 +算法 =程序 完整的程序设计应该是: 数据结构+算法+程序设计方法+语言工具 广义地说,为解决一个问题而采取的方法和步骤,就称为“算法”。 对同一个问题,可有不同的解题方法和步骤。为了有效地进行解题,不仅需要保证算法正确,还要考虑算

HBase抗战总结 | 阿里巴巴HBase高可用8年抗战回忆录

前言 2011年毕玄和竹庄两位大神将HBase引入阿里技术体系,2014年接力棒转到东8区第一位HBase commiter天梧手中,多年来与淘宝、旺旺、菜鸟、支付宝、高德、大文娱、阿里妈妈等几乎全BU合作伙伴携手共进,支撑了双十一大屏、支付宝账单、支付宝风控、物流详情等核心业务。2018年双十一,HBase全天处理请求2.4万亿行,单集群吞吐达到千万级别。从一个婴儿成长为青年,阿里HBase

PAT (Advanced Level) Practice——1011,1012

1011:  链接: 1011 World Cup Betting - PAT (Advanced Level) Practice (pintia.cn) 题意及解题思路: 简单来说就是给你3行数字,每一行都是按照W,T,L的顺序给出相应的赔率。我们需要找到每一行的W,T,L当中最大的一个数,累乘的结果再乘以0.65,按照例子写出表达式即可。 同时还需要记录每一次选择的是W,T还是L