当前位置: 首页 > 编程日记 > 正文

洛谷 P5019 铺设道路(差分)

嗯...

题目链接:https://www.luogu.org/problem/P5019

首先简化一下题意:

给定一个长为N的数组,每次操作可以选择一个区间减去1,问最少多少次操作可以将数组中的数全变成0 N≤100000

思路:

首先对于第一个数字d_1我们至少需要在上面花d_i次,然后考虑每一个d_i,对于它比上一个数字小(或等于)的那一部分,

我们可以在对上一个数字操作时一块操作。如果d_i > d_i - 1,也就是说它比上一个数大,那么我们就必须多进行d_i - d_i - 1次操作。

很明显,数与数之间会有差,而差会造成一些区间问题,所以这道题的正解是差分...

我们用b数组维护差分,然后将大于0的差分数组加到ans中即可。

AC代码:

 1 #include<cstdio>
 2 #include<iostream>
 3 
 4 using namespace std;
 5 
 6 int ans, d[100005], b;
 7 
 8 int main(){
 9     int n;
10     scanf("%d", &n);
11     for(int i = 1; i <= n; i++){
12         scanf("%d", &d[i]);
13         b = d[i] - d[i - 1];
14         if(b > 0) ans += b;
15     }
16     printf("%d", ans);
17     return 0;
18 }
19     
AC代码

转载于:https://www.cnblogs.com/New-ljx/p/11267087.html

相关文章:

1小时教你做360度全景“小星球”效果图 Skillshare – Create a Panoramic ‘Little Planet’ from Anywhere

1小时教你做360度全景“小星球”效果图 Skillshare – Create a Panoramic ‘Little Planet’ from Anywhere 1小时教你做360度全景“小星球”效果图 Skillshare – Create a Panoramic ‘Little Planet’ from Anywhere 时长1h 2m 1280X720 MP4 语言&#xff1a;英语中文字幕…

BIO、NIO、AIO详解

BIO(Blocking I/O)就是传统的Java IO编程,其相关的类和接口在java.io包下。BIO是同步阻塞的,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销,可以通过线程池机制改善(实现多个客户连接服务器)服务器端启动一个,注册端口,调用accpet方法监听客户端的Socket连接客户端启动Socket对服务器进行通信,默认情况下服务器端需要对每个客户建立一个线程与之通讯。

Java学习总结:12

多态性 1.方法的多态性&#xff1a;重载和覆写 重载&#xff1a;同一个方法名称&#xff0c;根据不同的参数类型及个数可以完成不同的功能&#xff1b; 覆写&#xff1a;同一个方法&#xff0c;根据不同的实例化的子类对象不同&#xff0c;所完成的功能也不同。 2.对象的多态性…

10万字总结Java8到21新特性详解

Java 8 是Java历史上一个重大的版本更新,发布于2014年3月18日。Lambda 表达式是在 Java 8 中引入,并且被吹捧为 Java 8 最大的特性。它是函数式编程的的一个重要特性,标志着 Java 向函数式编程迈出了重要的第一步。或者其中parameters:是 Lambda表达式的参数列表,可以为空或包含一个或多个参数。->:是 Lambda 操作符,用于将参数和 Lambda 主体分开。expression:是 Lambda 表达式的返回值,或者在主体中执行的单一表达式。

10万字总结Java8到21新特性详解

Java 17,发布于 2021 年 9 月,是一个长期支持(LTS)版本。Java 18,于2022年3月发布。Java 19, 于2022-09-20 发布众所周知,JVM 是一个多线程环境,它通过为我们提供了对操作系统线程的抽象,但是 Java 中的线程都只是对操作系统线程的一种简单封装,我们可以称之为“平台线程”。代价昂贵:创建平台线程的成本很高。每当创建一个平台线程时,操作系统都必须在堆栈中分配大量内存来存储线程的上下文、原生调用堆栈和 Java 调用堆栈。

iOS 对UIImage进行的一些操作

1、生成指定宽高的UIImage对象(oldImage为原始图片对象,newImage为操作后的图片对象) // 参数1:图片的尺寸 参数2:是否透明(没看出YES和NO有什么区别) 参数3:缩放(1表示不缩放) (1) UIGraphicsBeginImageContextWithOptions(CGSize size, BOOL opaque, CGFloat scale) (2) U…

mysql基础之视图

原文:mysql基础之视图 在查询中,我们经常把查询结果 当成临时表来看. View是什么? View可以看一张虚拟表. 是表通过某种运算得到的一个投影. 既然视图只是表的某种查询的投影,所以主要步骤在于查询表上.查询的结果命名为视图就可以了. 视图与表的关系 视图是表的查询结果,自然…

Maya教程-XGEN制作毛发技能学习 Patreon – Cartoon Grooming Series by Jesus FC

Maya教程-XGEN制作毛发技能学习 Patreon – Cartoon Grooming Series by Jesus FC Maya教程-XGEN制作毛发技能学习 Patreon – Cartoon Grooming Series by Jesus FC Maya教程-XGEN制作毛发技能学习 Patreon – Cartoon Grooming Series by Jesus FC Patreon – Cartoon Groom…

2.抽取代码(BaseActivity)

知识点俩种退出程序的方法复制集合同步的用法字符数组工厂模式&#xff0c;生产fatgment&#xff0c;解决了碎片重复创建的问题全局上下文actionbar用法fargmentadapter&#xff0c;当viewpager里是fargment的话更方便1.抽取BaseActivity 管理所有activity 方便退出 public c…

C语言画圆(编译器:VS2013)

一.graphics.h库的添加 方法一 先下载所需文件&#xff1a; graphic头文件解决方法&#xff08;密码&#xff1a;6z3y&#xff09; 1.先打开include文件夹 2.将里面的文件复制粘贴到VS2013安装目录的include文件夹中&#xff0c;如下&#xff1a; 3.打开下载好的文件夹中的…

JVM内存调优原则及几种JVM内存调优方法

JVM内存调优原则及几种JVM内存调优方法 1、堆大小设置。 2、回收器选择。 1、在对JVM内存调优的时候不能只看操作系统级别Java进程所占用的内存&#xff0c;这个数值不能准确的反应堆内存的真实占用情况&#xff0c;因为GC过后这个值是不会变化的&#xff0c;因此内存调优的时…

Meta标签中的format-detection属性及含义

format-detection翻译成中文的意思是“格式检测”&#xff0c;顾名思义&#xff0c;它是用来检测html里的一些格式的&#xff0c;那关于meta的format-detection属性主要是有以下几个设置&#xff1a;meta name"format-detection" content"telephoneno"meta…

Unity 3D游戏代码编程学习教程 Full Guide To Unity 3D C#: Learn To Code Making 3D Games

Unity 3D游戏代码编程学习教程 Full Guide To Unity 3D & C#: Learn To Code Making 3D Games Full Guide To Unity 3D & C#: Learn To Code Making 3D Games Unity 3D&C语言完整指南学习教程&#xff1a;学习编写3D游戏代码 由迈克尔穆尔创作|最后更新日期:2021年…

Java学习总结:13

抽象类 定义&#xff1a; 所谓抽象类就是指在普通类的结构里面增加抽象方法的组成部分&#xff0c;抽象方法指的是没有方法体的方法&#xff0c;同时抽象方法还必须使用abstract关键字进行定义。拥有抽象方法的类一定属于抽象类&#xff0c;抽象类要使用abstract声明。 关于抽…

九度OJ 1339:ACM (排序)

时间限制&#xff1a;1 秒 内存限制&#xff1a;32 兆 特殊判题&#xff1a;否 提交&#xff1a;712 解决&#xff1a;379 题目描述&#xff1a;今年的ACM世界总决赛快要开始了&#xff0c;需要有一个排名算法来对每支队伍进行现场排名。ACM组委会把这个任务交给了你&#xff0…

2022-2028年中国汽车印制电路板(汽车PCB)产业深度调研及投资前景预测报告

【报告类型】产业研究 【报告价格】4500起 【出版时间】即时更新&#xff08;交付时间约3个工作日&#xff09; 【发布机构】智研瞻产业研究院 【报告格式】PDF版 本报告介绍了中国汽车印制电路板(汽车PCB)行业市场行业相关概述、中国汽车印制电路板(汽车PCB)行业市场行业…

【VMCloud云平台】SCO(四)流程准备

在经过这么多介绍文章后&#xff0c;我们终于可以开始拨开云雾见真章了&#xff0c;今天来做一些制作流程前的预热。&#xff08;下图红色为部署中&#xff0c;紫色为实施完成&#xff0c;蓝色为计划中&#xff09;&#xff1a; 1、 流程&#xff0c;我们要了解它&#xff0c;可…

基本类型的数值转换

为了方便运算及调用一些方法&#xff0c;我们需要将基本类型的数值转换为对象&#xff1b;不过转换的时候需要特别注意好它们的类型到底是什么&#xff0c;需要调用方法的类名是哪个&#xff01;特别注意是Byte常量池的相关问题&#xff08;)&#xff1b;gc()垃圾回收机制的话&…

Java学习总结:14

接口 接口的基本定义 接口严格来讲属于一个特殊的类&#xff0c;而且这个类里面只有抽象方法与全局变量。 在java里面可以使用interface关键字来实现接口的定义。 例&#xff1a;定义接口 interface A{ //定义接口public static final String MSG"Hello World"; /…

Unity中创建本地多人游戏完整案例视频教程 Learn To Create A Local Multiplayer Game In Unity

Unity中创建本地多人游戏完整案例视频教程 Learn To Create A Local Multiplayer Game In Unity MP4 |视频:h264&#xff0c;1280x720 |音频:AAC&#xff0c;44.1 KHz&#xff0c;2 Ch 流派:电子学习|语言:英语原英文字幕 &#xff08;机译中文字幕&#xff09;|时长:15章 70…

第十二周 11.15-11.21

11.15 补个BC。 HDU 5565 Clarke and baton 没太懂题解怎么搞。反正挺暴力过了。 1 #include <iostream>2 #include <cstdio>3 #include <map>4 #include <vector>5 #include <algorithm>6 using namespace std;7 typedef long long LL;8 const …

Java 多线程的基本方式

Java 多线程的基本方式 基础实现两种方式&#xff1a; 通过实现Callable 接口方式&#xff08;可得到返回值)&#xff1a;

一次HP 阵列卡排障

公司使用的是HP gen8机器&#xff0c;用的是p420i阵列卡&#xff0c;同时在系统的另一端&#xff0c;nagios监控系统配合nrpe脚本check_hpasm定期检测硬件健康。最近为了让机器更带劲&#xff0c;加上了SSD硬盘&#xff0c;机械硬盘仅用作大容量存储&#xff0c;在感受速度与激…

集合、泛型、增强for

对于集合&#xff0c;首先要明确的是最顶层的接口是Collection接口类&#xff0c;其包含一些基本的方法以便子类调用&#xff0c;不过在定义的时候最好定义好数据类型&#xff0c;以免遍历时还得必须进行向上转型&#xff1b;特别注意的是其没有关于下标的方法。同时为了方便遍…

【强推】Blender制作逼真人物角色完整案例视频教程

【强推】Blender制作逼真人物角色完整案例视频教程 【强推】Blender制作逼真人物角色完整案例视频教程 时长53h 30m 1280X720 MP4 含教程工程文件 共九大模块 130小节课程 教程大小&#xff1a;12.9G 语言:英语机译中文字幕&#xff08;含原英文字幕文件&#xff09; Victory…

Java学习总结:15

Object类 Object类的基本定义 Object类是所有类的父类&#xff0c;也就是说任何一个类在定义时如果没有明确地继承一个父类&#xff0c;那它就是Object类的子类。 取得对象信息&#xff1a;toString() 在Object类中的toString()方法设计时&#xff0c;由于要考虑其可以满足…

ECMAScript——引用数据类型之array

array 转载于:https://www.cnblogs.com/cataway/p/4967058.html

2022-2028年中国炼钢行业市场研究及前瞻分析报告

【报告类型】产业研究 【报告价格】4500起 【出版时间】即时更新&#xff08;交付时间约3个工作日&#xff09; 【发布机构】智研瞻产业研究院 【报告格式】PDF版 本报告介绍了中国炼钢行业市场行业相关概述、中国炼钢行业市场行业运行环境、分析了中国炼钢行业市场行业的…

mvc存储Cookie和读取Cookie方法

mvc存储Cookie和读取Cookie方法&#xff1a;//存储HttpCookie cookie new HttpCookie("User");System.Text.Encoding enc System.Text.Encoding.GetEncoding("gb2312");cookie["id"] HttpUtility.UrlEncode(logid.ToString(), enc);cookie[&q…

AJAX 简介

什么是 AJAX &#xff1f; AJAX 异步 JavaScript 和 XML。 AJAX 是一种用于创建快速动态网页的技术。 通过在后台与服务器进行少量数据交换&#xff0c;AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下&#xff0c;对网页的某部分进行更新。 传统的网…