1350: To Add Which? (优先队列+贪心 或者 数组模拟)
1350: To Add Which?
Submit Page Summary Time Limit: 1 Sec Memory Limit: 128 Mb Submitted: 303 Solved: 134
Description
There is an integer sequence with N integers. You can use 1 unit of cost to increase any integer in the sequence by 1.
Could you tell us the least units of cost to achieve that, the absolute value of difference between any two adjacent integers is not more than D?
Input
The first line has one integer T, means there are T test cases.
For each test case, the first line has two integers N, D (1 <= N <= 105, 0 <= D < 109), which have the same meaning as above. The next line has N integers describing the sequence. Every integer in this sequence is in range [0, 109).
The size of the input file will not exceed 5MB.
Output
For each test case, print an integer in one line, indicates the desired answer.
Sample Input
3
5 2
1 3 5 3 5
5 1
1 2 3 5 6
5 2
1 7 3 5 9
Sample Output
0
3
8
Hint
Source
给你一个长度为n的序列
每次操作可以使得序列中某个数加1
问你最少操作多少次
可以使得序列相邻的元素的差值的绝对值都是d
做过一个非常非常类似这个题目的题
是开数组写的
没有用优先队列
因为那个时候还不会用优先队列!!!!!
GG
大数不会变大,变化的是小数。这个是解题的核心
贪心的思想
每次取出序列最大的数,扩展左右2个点。
比如样例 1 7 3 5 9
最大是9 扩展左边(无右边) 5+2变成7 刚好相差2 改变后的序列:1 7 3 7 9
现在9不用看了,弹出队列了
看最大的7(两个7,就看后面那个吧),现在第二个7左边的3扩展 3+2=5 扩展后的序列 1 7 5 7 9
现在7弹出了还有 1 7 5
看最大的7
扩展7的左边:1+4扩展成5 和7刚好相差2
再扩展7右边的5,发现不用扩展了
现在点都扩展了
在扩展过程中
记录花费
就是结果
注意的地方:
扩展过的点不用再扩展了
左端点只有扩展右边
右端点只要扩展左边
其余双向扩展
#include<stdio.h>
#include<iostream>
#include<math.h>
#include<algorithm>
#include<memory.h>
#include<memory>
#include<queue>
using namespace std;
#define max_v 1000005
typedef long long LL;
int t,n,d;
LL sum;
int a[max_v];
struct node
{
int v,id;
friend bool operator<(node a,node b)
{
return a.v<b.v;
}
};
priority_queue<node>q;
int main()
{
scanf("%d",&t);
while(t--)
{
sum=; node p,p1; while(!q.empty()) q.pop(); scanf("%d%d",&n,&d); for(int i=;i<n;i++)
{
scanf("%d",&a[i]);
p.id=i;
p.v=a[i];
q.push(p);
} while(!q.empty())
{
p=q.top();
q.pop(); if(p.v==a[p.id])
{
if(p.id>=)
{
if(p.v-a[p.id-]>d)
{
sum+=(p.v-d-a[p.id-]);
a[p.id-]=p.v-d;
p1.v=a[p.id-];
p1.id=p.id-;
q.push(p1);
}
}
if(p.id<n-)
{
if(p.v-a[p.id+]>d)
{
sum+=(p.v-d-a[p.id+]);
a[p.id+]=p.v-d;
p1.v=a[p.id+];
p1.id=p.id+;
q.push(p1);
}
}
}
}
printf("%lld\n",sum);
}
return ;
}
/*
题目意思:
给你一个长度为n的序列
每次操作可以使得序列中某个数加1
问你最少操作多少次
可以使得序列相邻的元素的差值的绝对值都是d 做法:
做过一个非常非常类似这个题目的题
是开数组写的
没有用优先队列
因为那个时候还不会用优先队列!!!!!
GG
大数不会变大,变化的是小数。这个是解题的核心
贪心的思想
每次取出序列最大的数,扩展左右2个点。
比如样例 1 7 3 5 9
最大是9 扩展左边(无右边) 5+2变成7 刚好相差2 改变后的序列:1 7 3 7 9
现在9不用看了,弹出队列了
看最大的7(两个7,就看后面那个吧),现在第二个7左边的3扩展 3+2=5 扩展后的序列 1 7 5 7 9
现在7弹出了还有 1 7 5
看最大的7
扩展7的左边:1+4扩展成5 和7刚好相差2
再扩展7右边的5,发现不用扩展了
现在点都扩展了
在扩展过程中
记录花费
就是结果
注意的地方:
扩展过的点不用再扩展了
左端点只有扩展右边
右端点只要扩展左边
其余双向扩展 */
数组模拟:
#include<stdio.h>
#include<math.h>
#include<algorithm>
using namespace std;
#define max_v 100005
typedef long long LL;
LL a[max_v];
LL maxx[max_v];
LL minx[max_v];
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int n;
LL d;
scanf("%d %lld",&n,&d);
for(int i=;i<n;i++)
scanf("%lld",&a[i]); maxx[]=a[];
for(int i=;i<n;i++)
{
if(maxx[i-]-a[i]>d)
maxx[i]=maxx[i-]-d;
else
maxx[i]=a[i];
} minx[n-]=a[n-];
for(int i=n-;i>=;i--)
{
if(minx[i+]-a[i]>d)
minx[i]=minx[i+]-d;
else
minx[i]=a[i];
} LL ans=;
for(int i=;i<n;i++)
ans+=(max(maxx[i],minx[i])-a[i]);
printf("%lld\n",ans);
}
return ;
}
1350: To Add Which? (优先队列+贪心 或者 数组模拟)的更多相关文章
- 最高的奖励 - 优先队列&贪心 / 并查集
题目地址:http://www.51cpc.com/web/problem.php?id=1587 Summarize: 优先队列&贪心: 1. 按价值最高排序,价值相同则按完成时间越晚为先: ...
- POJ2431 优先队列+贪心 - biaobiao88
以下代码可对结构体数组中的元素进行排序,也差不多算是一个小小的模板了吧 #include<iostream> #include<algorithm> using namespa ...
- 【bzoj4278】[ONTAK2015]Tasowanie 贪心+后缀数组
题目描述 给定两个数字串A和B,通过将A和B进行二路归并得到一个新的数字串T,请找到字典序最小的T. 输入 第一行包含一个正整数n(1<=n<=200000),表示A串的长度. 第二行包含 ...
- 【bzoj1692】[Usaco2007 Dec]队列变换 贪心+后缀数组
题目描述 FJ打算带他的N(1 <= N <= 30,000)头奶牛去参加一年一度的“全美农场主大奖赛”.在这场比赛中,每个参赛者都必须让他的奶牛排成一列,然后领她们从裁判席前依次走过. ...
- hdu3438 Buy and Resell(优先队列+贪心)
Buy and Resell Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)To ...
- POJ - 3476 A Game with Colored Balls---优先队列+链表(用数组模拟)
题目链接: https://cn.vjudge.net/problem/POJ-3476 题目大意: 一串长度为N的彩球,编号为1-N,每个球的颜色为R,G,B,给出它们的颜色,然后进行如下操作: 每 ...
- POJ 1330 Tarjan LCA、ST表(其实可以数组模拟)
题意:给你一棵树,求两个点的最近公共祖先. 思路:因为只有一组询问,直接数组模拟好了. (写得比较乱) 原题请戳这里 #include <cstdio> #include <bits ...
- 数组模拟循环队列(java实现)
1.front变量的含义:front就指向队列的第一个元素,也就是说arr[front]就是队列的第一个元素front的初始值=0. 2.rear变量的含义:rear指向队列的最后一个元素的后一个位置 ...
- 【数组模拟的链表or复杂模拟】PAT-L2-002. 链表去重
L2-002. 链表去重 给定一个带整数键值的单链表L,本题要求你编写程序,删除那些键值的绝对值有重复的结点.即对任意键值K,只有键值或其绝对值等于K的第一个结点可以被保留.同时,所有被删除的结点必须 ...
随机推荐
- Spring Boot—11控制器Controller
package com.sample.smartmap.controller; import org.springframework.beans.factory.annotation.Autowire ...
- join() 方法详解及应用场景
总结:join方法的功能就是使异步执行的线程变成同步执行.也就是说,当调用线程实例的start方法后,这个方法会立即返回,如果在调用start方法后后需要使用一个由这个线程计算得到的值,就必须使用jo ...
- CSS 内外边距 float positio属性
一.外边距和内边 margin: 用于控制元素与元素之间的距离 外边距:margin的最基本用途就是控制元素周围空间的间隔,从视觉角度上达到相互隔开的目的. padding: ...
- CSS深入理解之overflow(HTML/CSS)
简介 overflow看上去其貌不扬,其中蕴含的知识点还是很多的,有很多鲜为人知的特性表现. overflow基本属性值 1.visible(默认) 2.hidden 3.scroll 4.auto ...
- SQL Server ->> 存储过程sp_describe_first_result_set解析T-SQL语句的结果集结构信息
返回 Transact-SQL 批处理的第一个可能结果集的元数据. 如果批处理没有返回结果,则返回一个空的结果集. 如果数据库引擎无法确定将通过执行静态分析来执行的第一个查询的元数据,则引发错误. E ...
- 多线程应用-类(thread)
在对class thread加锁时,锁无法正常应用,函数方式没问题. 在使用class thread方法时,并发后的查询结果不对,函数方式没问题. # -*- coding: UTF-8 -*- fr ...
- 在虚拟机里安装linux(centos 6.5)系统
菜鸟一枚,也是接触linux系统没多长时间,前一阵子网上说有一个高级数据库工程师,因为rm -rf / 命令干掉了数据库-(nb),居然还跑路了!厉害了我的哥!也是闲的我蛋疼,在虚拟机里试了一批,本来 ...
- 安装启动apache2.4后报Invalid command 'order', perhaps misspelled or defined by a module not included
httpd.conf中修改 重启Apache 报错. 在网上搜索了一下,大多是说mod_authz_host.so模块没有加载,但检查后发现httpd.conf中: 该模块并未被注释掉,那原因究竟出在 ...
- 在 vSphere 5.x/6.0 中配置 Network Dump Collector 服务 (2002954)
vmware KB: https://kb.vmware.com/s/article/2002954?lang=zh_CN 重点配置命令: 使用 vSphere Client 连接到 vCenter ...
- php 导出
//导出 //放在model层的类 <?phpnamespace frontend\models; use yii\base\model; /** * @copyright (c) 2014 a ...