CSP-J 2023 T1 小苹果

题目

题目描述

小 Y 的桌子上放着 n n n 个苹果从左到右排成一列,编号为从 1 1 1 n n n

小苞是小 Y 的好朋友,每天她都会从中拿走一些苹果。

每天在拿的时候,小苞都是从左侧第 1 1 1 个苹果开始、每隔 2 2 2 个苹果拿走 1 1 1 个苹果。随后小苞会将剩下的苹果按原先的顺序重新排成一列。

小苞想知道,多少天能拿完所有的苹果,而编号为 n n n 的苹果是在第几天被拿走的?

输入格式

输入的第一行包含一个正整数 n n n,表示苹果的总数。

输出格式

输出一行包含两个正整数,两个整数之间由一个空格隔开,分别表示小苞拿走所有苹果所需的天数以及拿走编号为 n n n 的苹果是在第几天。

样例 #1

样例输入 #1

8

样例输出 #1

5 5

提示

【样例 1 1 1 解释】

小苞的桌上一共放了 8 8 8 个苹果。
小苞第一天拿走了编号为 1 1 1 4 4 4 7 7 7 的苹果。
小苞第二天拿走了编号为 2 2 2 6 6 6 的苹果。
小苞第三天拿走了编号为 3 3 3 的苹果。
小苞第四天拿走了编号为 5 5 5 的苹果。
小苞第五天拿走了编号为 8 8 8 的苹果。

【样例 2 2 2

见选手目录下的 apple/apple2.in 与 apple/apple2.ans。

【数据范围】

对于所有测试数据有: 1 ≤ n ≤ 1 0 9 1\leq n\leq 10^9 1n109

测试点 n ≤ n\leq n特殊性质
1 ∼ 2 1\sim 2 12 10 10 10
3 ∼ 5 3\sim 5 35 1 0 3 10^3 103
6 ∼ 7 6\sim 7 67 1 0 6 10^6 106
8 ∼ 9 8\sim 9 89 1 0 6 10^6 106
10 10 10 1 0 9 10^9 109

特殊性质:小苞第一天就取走编号为 n n n 的苹果。

题目传送门

洛谷 P9748 [CSP-J 2023] 小苹果

题解

思路

如果模拟是肯定会超时

那么我们就想想用数学方法来解决这道题

我们首先来考虑多少天能拿完所有苹果

就可以枚举天数,这样是不会超时的

设苹果数量为 n n n

那么每天 n n n 就会减少 ( n + 2 ) / 3 (n+2)/3 (n+2)/3

因为隔两个拿一个,那就可以三个三个分段,每段拿第一个

但是最后一段有可能不足三个,这样也会拿一个,所以不能光 n / 3 n/3 n/3

而用 ( n + 2 ) / 3 (n+2)/3 (n+2)/3 就可以了,这样 ( 4 + 2 ) / 3 = 2 (4+2)/3=2 (4+2)/3=2 ( 5 + 2 ) / 3 = 2 (5+2)/3=2 (5+2)/3=2 ( 6 + 2 ) / 3 = 2 (6+2)/3=2 (6+2)/3=2,就对了

得出代码(其中 d a y day day 是用来记录天数的, n n n 是输入的苹果数量):

int day;
while(n && ++day)
	n -= (n + 2) / 3;

然后我们考虑编号为 n 的苹果是在第几天被拿走的

首先在编号为 n n n 的苹果还没被拿走是编号为 n n n 的苹果无论哪天都一定是最后一个苹果

所以我们看现在的 n n n 除以 3 3 3 等于 1 1 1 就说明就说明该拿走编号为 n n n 的苹果了(因为每段都是拿走第 1 1 1 个,而 n n n 除以 3 3 3 等于 1 1 1 就说明编号为 n n n 的苹果是最后一段的第一个,该拿走了)

当然,如果已经有过这种情况了,那就不能更新答案

得出代码(和上一段代码合并了,其中 d a y day day 是用来记录天数的, a n s ans ans 是答案, n n n 是输入的苹果数量):

int day;
int ans;
while(n && ++day) {
	if(n % 3 == 1)
		if(!ans)
			ans = day;

	n -= (n + 2) / 3;
}

这就是整体思路

总代码

#include <cstdio>
using namespace std;

int n;
int day;
int ans;

int main() {
	scanf("%d", &n);
	
	while(n && ++day) {
		if(n % 3 == 1)
			if(!ans)
				ans = day;
		
		n -= (n + 2) / 3;
	}
	
	printf("%d %d\n", day, ans);
	
	return 0;
}

提交结果

戳这里看我的提交记录

提交结果

尾声

如果这篇题解对您(或您的团队)有帮助的话,就帮忙点个赞,加个关注!

最后,祝您(或您的团队)在 OI 的路上一路顺风!!!

┬┴┬┴┤・ω・)ノ Bye~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值