2021CCPC广州站C. Necklace

技术2021CCPC广州站C. Necklace 2021CCPC广州站C. Necklace题目:C. Necklace
题意:
https://codeforces.com/gym/103415/p

2021CCPC广州站c .项链

题目:C. Necklace

题意:

https://codeforces.com/gym/103415/problem/C

?长度为n的项链上有m颗珠子,每颗珠子分成一段,最长一段的最小长度被要求。

思路:二分+贪心

?每张支票贪婪地从第一个位置开始,所以开始时的最大偏移量为:n-a[m] a[1]-1,mi代表当前起始位置的最大偏移量,每个区间mi都要取最小值,否则初始位置偏移量会超过他的区间,cnt记录初始起始位置的最大向前偏移量。

代码:

#包含位/stdc。h

使用命名空间标准;

typedef long long ll

#定义整数长

const int mod=998244353

const int N=1e6 10

# define GC()(is==itit=(is=in)fread(in,1,Q,stdin),(is==itEOF:*is ):*is)

const int Q=(124)1;

char in[Q],*is=in,*it=in,c;

int n,m;

无效读取(long long n){ 0

for(n=0;(c=GC())“0”| | c“9”;);

for(;c=' 9 ' c=' 0c=GC())n=n * 10 c-48;

}

int a[N];

bool check(int x){ 0

int mi=n-a[m]a[1]-1;//当前起始位置的最大偏移量

int mm=mi

int now=0;//用于记录上一段需要下一段补充的大小。

int CNT=0;//记录初始起始位置的总最大向前偏移。

for(int I=1;im;I){ 0

int xx=x-now;//x-减去要分配给前一部分的值表示可以分配给当前时间间隔的值。

int cha=a[I 1]-a[I];//当前段的大小

如果(xx=0)返回false//如果不能分配到下一个区间,就是违法的。

if(chaxx){ 0

now=a[I 1]-(a[I]xx);

mi=min(mi,xx-1);

}

else{

now=0;

int m1=min(mi,xx-cha);

cnt=m1

mi=min(mi-m1,cha-1);

}

}

int ans=now mm 1-x;//当前段需要增加多少个前一段-x=当前段需要划分多少个偏移量。

if(x-now=mm 1||cnt=ans)返回true//可以给最后一个区间的值大于最后一个区间的大小或者可以移位的总量=仍然需要移位的量。

返回false

}

签名main(){ 0

IOs :3360 sync _ with _ stdio(false);

CIN . tie(0);cout . tie(0);

读(n),读(m);

for(int I=1;I=m;I){ 0

读作(a[I]);

}

int l=1,r=n;

while(lr){ 0

int mid=(l r)1;

if(check(mid))r=mid;

否则l=mid 1;

}

printf('%lld\n ',l);

返回0;

}

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/107449.html

(0)

相关推荐

  • Python编程为什么不使用print调试代码了

    技术Python编程为什么不使用print调试代码了这篇文章主要介绍“Python编程为什么不使用print调试代码了”,在日常操作中,相信很多人在Python编程为什么不使用print调试代码了问题上存在疑惑,小编查阅

    攻略 2021年10月25日
  • C语言----位运算,进阶篇二十六)

    技术C语言----位运算,进阶篇二十六) C语言----位运算(进阶篇二十六)作用在小内存时代,经常把一个字节分成好几份来用,以达到节约内存的目的。现在经常用于网络数据传输,单片机领域……。注意:※在进

    礼包 2021年11月1日
  • 用innobackupex对于全量备份恢复mysql出错的示例分析

    技术用innobackupex对于全量备份恢复mysql出错的示例分析这篇文章给大家分享的是有关用innobackupex对于全量备份恢复mysql出错的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随

    攻略 2021年11月6日
  • 如何使用attrs来告别Python中的样板

    技术如何使用attrs来告别Python中的样板如何使用attrs来告别Python中的样板,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。在

    攻略 2021年10月26日
  • 君越怎么样,君越的优点和缺点是什么

    技术君越怎么样,君越的优点和缺点是什么展开全部 1、车体宽大君越怎么样,大气,外形给人一种豪华上档次的感觉。 2、有全新四缸全铝发动机,据说油耗在6.2升/100公里/90公里等速,如果能真的达到这个标准,我感觉应该非

    生活 2021年10月25日
  • 抖音刷千粉,抖音刷粉1000人多少钱?

    技术抖音刷千粉,抖音刷粉1000人多少钱?抖音快速增长粉料的方法抖音无疑是目前新媒体中增长粉料最简单、增长最快的平台。从前,成都小甜甜一夜涨粉五百万,后来,灵魂当铺一天涨粉七十五万。这样的涨粉速度在其他平台是难以想象的。

    测评 2021年10月19日