当前位置:首页 > 复赛 > 正文内容

CSP-J2021年普及组复赛T1——分糖果

亿万年的星光4年前 (2021-11-06)复赛1784

【题目背景】

红太阳幼儿园的小朋友们开始分糖果啦!

【题目描述】

红太阳幼儿园有 n 个小朋友,你是其中之一。保证 n ≥ 2。 

有一天你在幼儿园的后花园里发现无穷多颗糖果,你打算拿一些糖果回去分给幼儿 园的小朋友们。 

由于你只是个平平无奇的幼儿园小朋友,所以你的体力有限,至多只能拿 R 块糖 回去。 

但是拿的太少不够分的,所以你至少要拿 L 块糖回去。保证 n ≤ L ≤ R。 

也就是说,如果你拿了 k 块糖,那么你需要保证 L ≤ k ≤ R。 

如果你拿了 k 块糖,你将把这 k 块糖放到篮子里,并要求大家按照如下方案分糖 果:只要篮子里有不. 少. 于. n 块糖果,幼儿园的所有 n 个小朋友(包括你自己)都从篮子 中拿走恰. 好. 一块糖,直到篮子里的糖数量少. 于. n 块。此时篮子里剩余的糖果均归你所有 ——这些糖果是作. 为. 你. 搬. 糖. 果. 的. 奖. 励. 。 

作为幼儿园高质量小朋友,你希望让作. 为. 你. 搬. 糖. 果. 的. 奖. 励. 的糖果数量(而. 不. 是. 你. 最. 后. 获. 得. 的. 总. 糖. 果. 数. 量!. )尽可能多;因此你需要写一个程序,依次输入 n, L, R,并输出 出你最多能获得多少作. 为. 你. 搬. 糖. 果. 的. 奖. 励. 的糖果数量。

【输入格式】

从文件 candy.in 中读入数据。 

输入一行,包含三个正整数 n, L, R,分别表示小朋友的个数、糖果数量的下界和上 界。

【输出格式】


输出到文件 candy.out 中。 

输出一行一个整数,表示你最多能获得的作. 为. 你. 搬. 糖. 果. 的. 奖. 励. 的糖果数量。

【样例1输入】

7 16 23

【样例1输出】

6

【样例1解释】

拿 k = 20 块糖放入篮子里。 

篮子里现在糖果数 20 ≥ n = 7,因此所有小朋友获得一块糖;

篮子里现在糖果数变成 13 ≥ n = 7,因此所有小朋友获得一块糖; 

篮子里现在糖果数变成 6 < n = 7,因此这 6 块糖是作. 为. 你. 搬. 糖. 果. 的. 奖. 励. 。 

容易发现,你获得的作. 为. 你. 搬. 糖. 果. 的. 奖. 励. 的糖果数量不可能超过 6 块(不然,篮子 里的糖果数量最后仍然不少于 n,需要继续每个小朋友拿一块),因此答案是 6。

【样例2输入】

10 14 18

【样例2输出】

8

【样例2解释】

容易发现,当你拿的糖数量 k 满足 14 = L ≤ k ≤ R = 18 时,所有小朋友获得一块 糖后,剩下的 k − 10 块糖总是作. 为. 你. 搬. 糖. 果. 的. 奖. 励. 的糖果数量,因此拿 k = 18 块是最 优解,答案是 8。

【数据范围】

测试点n<=R<=R-L<=
1255
251010
3103103103
4105105105
51031090
6103109103
7105109105
8109109109
9
109109109
10109109109

对于所有数据,保证 2 ≤ n ≤ L ≤ R ≤ 109。

【参考答案】

#include<iostream>
#include<cstdio>
using namespace std;
int main() {
	//freopen("candy.in","r",stdin);
	//freopen("candy.out","w",stdout);
	int n,l,r,ans=0;
	cin>>n>>l>>r;//人数,下限,上限 (10^9)
	if(r-l<n) {
		for(int i=r; i>=l; i--) {
			int tmp=i%n;
			if(tmp>ans)
				ans=tmp;
		}
	} else {
		ans=n-1;
	}
	cout<<ans;
	//fclose(stdin);
	//fclose(stdout);
	return 0;
}


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

NOIP2009年普及组T1 多项式输出

NOIP2009年普及组T1 多项式输出

【题目描述】一元 n 次多项式可用如下的表达式表示:其中,aixiaixi 称为ii次项,aiai称为ii次项的系数。给出一个一元多项式各项的次数和系数,请按照如下规定的格式要求输...

NOIP/CSPJ 复赛中noilinux里的atbiter测评机的使用(附数据)

NOIP/CSPJ 复赛中noilinux里的atbiter测评机的使用(附数据)

0.前言最近这段时间在研究noilinux,NOI考试中的测评系统就在noilinux中,叫做atbiter。自己百度了一下,发现说的都比较官方,自己尝试了一遍,把过程和数据附上,以供参考。1.创建比...

noiLinux中编程工具的使用

noiLinux中编程工具的使用

0.前言NOIP考试中,最终的程序要在noilinux中运行,以noilinux为准,但是有些省份做题基本就是DEVC++,有些细微的差别如果老师没讲过非常容易在考试中爆零。1.编程工具的选择关于no...

NOIP2003年普及组 T1 乒乓球

【题目描述】国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革,以推动乒乓球运动在全球的普及。其中11分制改革引起了很大的争议,有一部分球员因为无法适应新规则只能选择退役。华华就是其中一位,他退...

NOIP2008年普及组T1 ISBN号

【题目描述】每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字、1位识别码和3位分隔符,其规定格式如“x-xxx-xxxxx-x”,其中符号“-”是分隔符(键盘上的减号),最后一...

NOIP2010年普及组T2 接水问题

【题目描述】学校里有一个水房,水房里一共装有m 个龙头可供同学们打开水,每个龙头每秒钟的供水量相等,均为1。现在有n 名同学准备接水,他们的初始接水顺序已经确定。将这些同学按接水顺...