东方博宜24年8月-B组 - 小A切西瓜

本解析禁止用于商业用途

禁止在未经许可的情况下转载

本篇仅在CSDN发布

官方解析请访问24年东方博宜OJ编程月赛评讲课 - 网易云课堂

题目描述

炎热的夏天来了,小 A 买了半个西瓜,打算和信奥班的同学们一起分享。
老师借给了小 A 一把锋利的西瓜刀,小 A 可以借助这把西瓜刀,每次在西瓜的圆形切面上,完整且不弯曲的切一刀。
假设西瓜无限大,因此可以在这个圆形切面上无限切,请问小 A 切了 n 刀后,可以最多得到多少片西瓜。
下图给出了小 A 同学分别切 1 刀、 2 刀、 3 刀可以得到最多西瓜数的切法。

输入

一行一个整数 n ,表示切西瓜的次数。

输出

一行一个整数,表示最多能切出多少片西瓜。

样例

输入

2

输出

4

输入

7

输出

29

输入

30

输出

466

说明

数据范围
对于 30% 的数据,n≤3。
对于另外 40% 的数据, n≤10^5 。
对于另外 30% 的数据, n≤10^9 。

要解决这个问题,我们需要理解每次切割如何影响西瓜片的数量。每次切割时,我们希望尽可能多地增加西瓜片的数量。通过观察和推理,我们可以发现一个规律:每次切割时,如果新的切割线与之前的所有切割线相交,那么可以最大化西瓜片的数量。

具体来说,切第 n 刀时,如果这刀与之前的 n−1 刀都相交,那么会增加 n 片西瓜。因此,切 n 刀后,最多可以得到的西瓜片数是前 n 个自然数的和,即:

Sn=1+2+3+⋯+n=n(n+1)/2+1

这个公式可以通过数学归纳法证明。

具体步骤

  1. 输入处理:读取输入的整数 n。
  2. 计算结果:使用公式 n(n+1)/2+1 计算最多能切出的西瓜片数。
  3. 输出结果:将计算结果输出。

代码实现

#include <iostream>

int main() {
    long long n;
    std::cin >> n;
    
    // 计算最多能切出的西瓜片数
    long long result = (n * (n + 1)) / 2 + 1;
    
    // 输出结果
    std::cout << result << std::endl;
    
    return 0;
}

解释

  1. 输入处理:使用 std::cin 读取输入的整数 n。
  2. 计算结果:使用公式 n(n+1)/2+1 计算最多能切出的西瓜片数。这里使用 long long 类型来避免整数溢出问题,因为 n 可能非常大(达到 10^9)。
  3. 输出结果:使用 std::cout 输出计算结果。

这个算法的时间复杂度是 O(1),因为计算公式直接给出了结果,不需要循环或递归。因此,它可以高效地处理大规模数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值