Educational Codeforces Round 158 B. Chip and Ribbon (贪心)

有一条带子,分为 n 个单元格,从左到右编号为 1 至 n 。最初,每个单元格中都写入了一个整数 0 。

单细胞与芯片玩游戏。游戏由几个回合组成。在第一轮中,Monocarp 将芯片放入色带的 1 -st 单元中。除了第一轮之外,在每一轮中,Monocarp 都会做以下两个动作中的一个:

将芯片移动到下一个单元格(例如,如果芯片在 i 单元格,则将其移动到 i+1 单元格)。如果芯片位于最后一个单元格,则无法执行此操作;
选择任意一个单元格 x ,将芯片传送至该单元格。可以选择芯片当前所在的单元格。
每回合结束时,写入芯片所在单元格的整数会增加 1 。

Monocarp的目标是在某些回合中, 1 -st单元格中包含整数 c1 , 2 -nd单元格中包含整数 c2 ,…, n -th单元格中包含整数 cn 。他希望尽可能少地传送芯片。

请帮助 Monocarp 计算他传送芯片的最少次数。

输入
第一行包含一个整数 t ( 1 ≤ t ≤ 1 0 4 ) t ( 1≤t≤10^4 ) t(1t104) - 测试用例数。

每个测试用例由两行组成:

第一行包含一个整数 n ( 1 ≤ n ≤ 2 ⋅ 1 0 5 ) n ( 1≤n≤2⋅10^5 ) n(1n2105)
第二行包含 n n n 个整数 c 1 , c 2 , … , c n ( 0 ≤ c i ≤ 1 0 9 ; c 1 ≥ 1 ) c_1,c_2,…,c_n ( 0≤c_i≤10^9 ; c_1≥1 ) c1,c2,,cn(0ci109;c11)。可以证明,在这些限制条件下,总是可以进行有限次的转动,从而使单元格中的整数与序列 c 1 , c 2 , … , c n c_1,c_2,…,c_n c1,c2,,cn 一致。

输入的附加限制:所有测试用例中 n n n 的值之和不超过 2 ⋅ 1 0 5 2⋅10^5 2105

输出
对于每个测试用例,打印一个整数 - Monocarp 传送芯片的最少次数。


这个问题可以抽象为:将一个全为0的数组加成给定的数组,每次可以对从前往后的连续段加1,如果要跳过一个数就要加一步数,从头开始再来也要加一步数,求最小步数。

那么很容易想到一种贪心策略,只要每次扫完我们都尽量跳转到最左边要加的数就可以了。

首先思考,对于 c 1 c_1 c1 ,我们一定会需要的步数是 c 1 − 1 c_1 - 1 c11,在之后的过程中,我们会遇见两种情况。
一种情况是递减,另一种是递增。
如果当前是递增,那么必定会导致出现,当前的值变成0了,但是后面的值还不为0,这时候就会导致传送的操作,并且操作次数至少是后面的值比当前值大的差值。
但是如果是递减,那么必定会导致出现后面的值先为0,不会导致传送的出现。

所以只要用 c 1 − 1 c_1 - 1 c11 加上后面需要的传送的步数就可以了。


CODE:

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5+10;
#define endl '\n'
#define ll long long
#define int long long
int c[N];void solve(){int n;cin >> n;for(int i = 1;i <= n;i++)cin >> c[i];if(n == 1){cout << c[1] -1 << endl;return;}int res = c[1] - 1;for(int i = 2;i <= n;i++){res += max(c[i] - c[i-1],0ll);}cout << res << endl;
}signed main(){int T;cin >> T;while(T--){solve();}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/17061.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SSM基于微信小程序的校园表白墙的设计与实现-计算机毕业设计源码58219

摘 要 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据信息管理&#xff0c;对于手机的各种软件也是备受用户的喜爱&#xff0c;校园表白墙微信小程序被用户普遍使用&#xff0c;为方便用…

Java面试八股之自旋是什么意思

Java中的自旋是什么意思 自旋是多线程编程中的一种同步机制&#xff0c;尤其在Java中与锁的实现密切相关。当一个线程尝试获取某个锁&#xff08;如内置锁或显式锁&#xff09;时&#xff0c;如果锁已被其他线程持有&#xff0c;通常的做法是将该线程置于阻塞状态&#xff0c;…

图形学概述

图形学应用 游戏 游戏的画面好坏如何鉴定呢&#xff1f; 看游戏画面是否够亮&#xff1a;渲染中全局光照的好坏 《只狼》 为什么卡通游戏画面看起来是卡通的呢&#xff1f; 《无主之地3》 这些都是图形学需要着手解决的问题 电影 电影《黑客帝国》的特效也是通过计算机…

软件测试面试题(九)

一&#xff1a;说说你对SQA的职责和工作活动的理解&#xff1f; 答&#xff1a;SQA就是独立于软件开发的项目组&#xff0c;通过软件开发过程的监控&#xff0c;来保证软件开发流程按照指定的CMM规程&#xff0c;对于不符合项目及时提出来的建议和改进方案&#xff0c;必要是可…

HTTPS加密过程

今天我们说https具体工作原理。 HTTPS概念 HTTPS是一种网络协议&#xff0c;传统的HTTP是明文传输&#xff0c;非常 不安全&#xff0c;所以HTTPS是基于HTTP基础上进行加密传输内容。 HTTPS使用加密传输方式 第一种是非对称加密&#xff0c;是前期建立连接时候使用的数据加密…

Unity 直线间隔放置物体

直线间隔放置物体 0. 新建一个空物体&#xff0c;挂上脚本ZYF_QuickPlaceObj 设置 间隔距离 和 预制体在Scene中拖动即可按间隔距离实例化物体物体的朝向始终朝向统一方向&#xff0c;并且可以在Scene中拖拽更改 传送门

QML-1- qml简介及项目创建

文章目录 1. QML 简介2. 项目创建3. 目录结构4. CMakeLists.txt 简单介绍5. 运行demo 1. QML 简介 根据官网介绍&#xff0c;qml 为qt一个模块&#xff0c;使用Qml语言开发应用程序和库提供了一个框架。它定义并实现了语言和引擎基础结构&#xff0c;并提供了一个API&#xff…

jQuery事件导读+其它方法

jQuery 事件导读一、事件注册二、事件处理1.内容2.例子&#xff0c;微博绑定事件3.off解绑事件4.自动触发事件 三、事件对象 其他方法一、拷贝对象二、多库共存三、插件 事件导读 一、事件注册 单个事件叫注册&#xff0c;多个事件叫处理 二、事件处理 1.内容 2.例子&#…

Pytorch中乘法函数torch.matmul() 的一种用法

主要记录下torch.matmul(A,B)的用法中的一种情况&#xff1a; 当A&#xff0c;B有一个是3维以上&#xff0c;另一个是3维或3维以上时&#xff0c;如果想要使用torch.matmul(A,B)&#xff0c;必须同时满足&#xff1a; 1.A和B的最后两个维度满足矩阵乘法的要求。例如A的维度是…

今日上新——FCP

今年2月&#xff0c;我们FCC-E产品全新上线了专有D区&#xff0c;专门满足用户对高性价比的稀缺大机型需求。 产品研发组的小伙伴们根本停不下来~ 才几个月&#xff0c;我们又又上新了&#xff01; 今天的新品是FCP&#xff08;fastone Compute Platform&#xff09;&#x…

VMware ESXi中安装Proxmox VE

0、巴拉巴拉 前几天某行业HW&#xff0c;闲暇的时候几个技术人员聊天&#xff0c;臭味相投的聊到自己玩的东西。有个玩家说家里用工作站安装Proxmox VE&#xff0c;然后在上面安装软路由、安装NAS。我以前一直想玩玩&#xff0c;没有付诸行动&#xff0c;所以也想弄个集中的方案…

分享目前堪称最好用的车机桌面app,支持画中画模式!

好用的车机桌面了&#xff0c;支持悬浮画中画&#xff01; 如果你想改变单调的车机桌面&#xff0c;那么这篇文章你不要错过了&#xff01;支持地图悬浮、画中画的车机桌面&#xff0c;不要错过&#xff01; 今天阿星给大家分享3款好用、好看的大屏桌面软件&#xff0c;重要的…

如何在Namecheap上购买域名

文章目录 如何在Namecheap上购买国外域名&#xff0c;话不多说直接上步骤↓1&#xff1a;注册Namecheap账号2&#xff1a;选购域名3&#xff1a;如何付款4&#xff1a;付款购买域名5&#xff1a;总结 如何在Namecheap上购买国外域名&#xff0c;话不多说直接上步骤↓ 原文链接…

学习双向链表带哨兵demo

定义 在计算机科学中&#xff0c;链表是数据元素的线性集合&#xff0c;其每个元素都指向下一个元素&#xff0c;元素存储上并不连续。 双向链表&#xff0c;每个元素知道其上一个元素和下一个元素。 以下为示例代码&#xff1a; package com.tfq.arithmetic.linkedlist;imp…

Flask 蓝图路由的模块化开发

基于 Flask 蓝图路由的模块化开发 1. 编程目标 为了提高Flask应用的可维护性和可扩展性&#xff0c;我们通过使用Flask的蓝图(Blueprint)功能&#xff0c;可以将不同的功能模块拆分到独立的文件中&#xff0c;方便后续的开发和维护。 2. 项目结构 项目结构树如下&#xff1…

C++设计模式之单例模式、模板模式、状态模式、原型模式、CRTP 模式、组件模式、观察者模式、发布-订阅模式、访问者模式

文章目录 参考 参考 游戏开发中经常用到的设计模式【C】游戏开发常用的设计模式&#xff0c;高手都这样写&#xff1f;单例模式、组件模式、原型模式、访问者模式等

假如Redis⾥里里⾯面有1亿个key,其中有10w个key是以某个固定的已知的前缀开头的,如何将它们全部找出来?

使⽤用 keys 指令可以扫出指定模式的 key 列列表。但是要注意 keys 指令会导致线程阻塞⼀一段时间&#xff0c;线上服务会停 顿&#xff0c;直到指令执⾏行行完毕&#xff0c;服务才能恢复。这个时候可以使⽤用 scan 指令&#xff0c; scan 指令可以⽆无阻塞的提取出指定模式 的…

高斯过程学习笔记

目录 基础知识 例子 推荐 A Visual Exploration of Gaussian Processes (distill.pub) AB - Introduction to Gaussian Processes - Part I (bridg.land) 基础知识 高斯过程回归&#xff08;Gaussian Process Regression&#xff09; - 知乎 (zhihu.com) 高斯过程&#x…

破译智能密码:大模型进阶之路

人工智能浪潮席卷全球&#xff0c;大模型&#xff08;Large Language Models&#xff09;作为其核心技术之一&#xff0c;正以惊人的速度改变着我们的世界。从创作诗歌、编写代码到提供医疗咨询&#xff0c;大模型在各行各业中展现出令人瞩目的能力。然而&#xff0c;要让这些“…

马斯克xAI公司获60亿美元融资,超级计算工厂将于2025年秋季前问世

马斯克旗下的xAI公司宣布了一项令人瞩目的计划——建造一个名为“超级计算工厂”的巨型超级计算机。这一前所未有的项目不仅体现了马斯克对于人工智能&#xff08;AI&#xff09;技术的深刻洞察&#xff0c;也彰显了他在技术创新上的坚定决心。 据悉&#xff0c;超级计算工厂将…