C语言基础题:吃冰棍(C语言版)

1.题目描述

机器猫喜欢吃冰棍。

买一根冰棍,吃完了会剩一个木棒;每三个木棒可以兑换一个冰棍。兑换出来的冰棍,吃完之后也能剩下一个木棒。

所以,如果机器猫买了5根冰棍,他可以吃完之后得到5个木棒;拿3个木棒兑换1根冰棍,余2个木棒;吃完兑换来的冰棍之后,手上有3个木棒,又能兑换一个冰棍。最后,机器猫实际上吃了7个冰棍。

机器猫想要吃到 几 个冰棍,想问最开始至少需要去买多少根冰棍?

2.输入格式

仅一行,一个正整数,表示 n。

3.输出格式

仅一行,一个正整数,表示需要买的冰棍数量。

4.输入输出样例

输入1:
cpp 复制代码
7
输出1:
cpp 复制代码
5
输入2:
cpp 复制代码
20
输出2:
cpp 复制代码
14

5.说明/提示

数据规模与约定

对于 100% 的数据,1 <n< 100000000.

代码:

cpp 复制代码
#include <stdio.h>

int main() {
    long long n;
    scanf("%lld", &n);

    long long left = 0, right = n; // 最少0根,最多n根
    long long result = n;

    while (left <= right) {
        long long mid = left + (right - left) / 2;
        long long totalIceCreams = mid; // 起始购买的冰棍数量
        long long sticks = mid; // 吃完后剩下的木棒

        // 计算可以吃到多少冰棍
        while (sticks >= 3) {
            long long newIceCreams = sticks / 3;
            totalIceCreams += newIceCreams;
            sticks = sticks % 3 + newIceCreams; // 剩下的木棒加上新的木棒
        }

        if (totalIceCreams >= n) {
            result = mid; // 可以满足条件,记录结果
            right = mid - 1; // 尝试更少的冰棍
        } else {
            left = mid + 1; // 需要更多的冰棍
        }
    }

    printf("%lld\n", result);
    return 0;
}
相关推荐
AitTech6 分钟前
C#编程:List.ForEach与foreach循环的深度对比
开发语言·c#·list
阿俊仔(摸鱼版)21 分钟前
Python 常用运维模块之OS模块篇
运维·开发语言·python·云服务器
军训猫猫头21 分钟前
56.命令绑定 C#例子 WPF例子
开发语言·c#·wpf
sunly_28 分钟前
Flutter:自定义Tab切换,订单列表页tab,tab吸顶
开发语言·javascript·flutter
远方 hi39 分钟前
linux虚拟机连接不上Xshell
开发语言·php·apache
涅槃寂雨39 分钟前
C语言小任务——寻找水仙花数
c语言·数据结构·算法
『往事』&白驹过隙;1 小时前
操作系统(Linux Kernel 0.11&Linux Kernel 0.12)解读整理——内核初始化(main & init)之缓冲区的管理
linux·c语言·数据结构·物联网·操作系统
就爱学编程1 小时前
从C语言看数据结构和算法:复杂度决定性能
c语言·数据结构·算法
涛ing1 小时前
23. C语言 文件操作详解
java·linux·c语言·开发语言·c++·vscode·vim
NoneCoder1 小时前
JavaScript系列(42)--路由系统实现详解
开发语言·javascript·网络