news 2026/4/18 13:55:39

(新B卷,100分)- 分糖果(Java JS Python C)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(新B卷,100分)- 分糖果(Java JS Python C)

(新B卷,100分)- 分糖果(Java & JS & Python & C)

题目描述

小明从糖果盒中随意抓一把糖果,每次小明会取出一半的糖果分给同学们。

当糖果不能平均分配时,小明可以选择从糖果盒中(假设盒中糖果足够)取出一个糖果或放回一个糖果。

小明最少需要多少次(取出、放回和平均分配均记一次),能将手中糖果分至只剩一颗。

输入描述

抓取的糖果数(<10000000000):15

输出描述

最少分至一颗糖果的次数:5

用例
输入15
输出5
说明
  1. 15+1=16;
  2. 16/2=8;
  3. 8/2=4;
  4. 4/2=2;
  5. 2/2=1;
题目分析

本题由于是每次折半,因此本题数量级即便很大,也不怕超时。

没有了超时的后顾之忧,本题,直接可以暴力逻辑求解,假设输入的是num,分配次数count初始为0,那么:

  • 如果num % 2 == 0,则可以直接折半,此时分配次数count++, num /= 2
  • 如果num % 2 !=0,则不可以直接折半,此时需要开两个分支:
  1. 取出一个糖,即num += 1,然后分配次数count++,之后继续前面折半逻辑
  2. 放回一个糖,即num -= 1,然后分配次数count++,之后继续前面折半逻辑

最终我们只需要在众多分支中,取最少的count即可。

上面逻辑可以基于递归实现。具体实现请看代码。

Java算法源码
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println(getResult(sc.nextLong())); } public static long getResult(long num) { int[] ans = {Integer.MAX_VALUE}; recursive(num, 0, ans); return ans[0]; } public static void recursive(long num, int count, int[] ans) { if (num == 1) { ans[0] = Math.min(ans[0], count); return; } if (num % 2 == 0) { recursive(num / 2, count + 1, ans); } else { recursive(num + 1, count + 1, ans); recursive(num - 1, count + 1, ans); } } }
JS算法实现
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { console.log(getResult(Number(line))); }); function getResult(num) { ans = [Infinity]; recursive(num, 0, ans); return ans[0]; } function recursive(num, count, ans) { if (num == 1) { ans[0] = Math.min(ans[0], count); return; } if (num % 2 == 0) { recursive(num / 2, count + 1, ans); } else { recursive(num + 1, count + 1, ans); recursive(num - 1, count + 1, ans); } }
Python算法源码
import sys # 输入获取 num = int(input()) def recursive(num, count, ans): if num == 1: ans[0] = min(ans[0], count) return if num % 2 == 0: recursive(num // 2, count + 1, ans) else: recursive(num + 1, count + 1, ans) recursive(num - 1, count + 1, ans) # 算法入口 def getResult(): ans = [sys.maxsize] recursive(num, 0, ans) return ans[0] # 算法调用 print(getResult())
C算法源码
#include <stdio.h> #include <limits.h> #define MIN(a,b) (a) < (b) ? (a) : (b) void recursive(long long num, int count); int ans = INT_MAX; int main() { long long num; scanf("%lld", &num); recursive(num, 0); printf("%d\n", ans); return 0; } void recursive(long long num, int count) { if(num == 1) { ans = MIN(ans, count); return; } if(num % 2 == 0) { recursive(num / 2, count + 1); } else { recursive(num + 1, count + 1); recursive(num - 1, count + 1); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 14:01:45

LeakCanary 检测内存泄漏的核心原理

LeakCanary 检测内存泄漏的核心原理 LeakCanary 是 Android 平台常用的内存泄漏检测工具,但在实际开发中,生命周期较长的对象、系统组件缓存、第三方库内部逻辑等场景容易引发误报。要避免误报,核心思路是 明确区分「真正的内存泄漏」和「合法的长生命周期引用」,可以从以…

作者头像 李华
网站建设 2026/4/18 5:40:39

(论文速读)卷积层谱范数的紧凑高效上界

论文题目&#xff1a;Tight and Efficient Upper Bound on Spectral Norm of Convolutional Layers&#xff08;卷积层谱范数的紧凑高效上界&#xff09;会议&#xff1a;ECCV2024摘要&#xff1a;控制与卷积运算相关的雅可比矩阵的谱范数可以提高cnn的泛化、训练稳定性和鲁棒性…

作者头像 李华
网站建设 2026/4/18 5:30:53

终极网站下载工具:5分钟学会整站备份与离线浏览

终极网站下载工具&#xff1a;5分钟学会整站备份与离线浏览 【免费下载链接】WebSite-Downloader 项目地址: https://gitcode.com/gh_mirrors/web/WebSite-Downloader 想要快速下载整个网站内容进行离线浏览或备份&#xff1f;WebSite-Downloader正是你需要的强大工具。…

作者头像 李华
网站建设 2026/4/18 6:57:36

Ollama模型格式转换为LLama-Factory兼容格式的全过程演示

Ollama模型格式转换为LLama-Factory兼容格式的全过程演示 在大模型落地实践中&#xff0c;一个常见的困境浮出水面&#xff1a;你在本地用 Ollama 快速验证了一个基于 Llama3 的智能客服原型&#xff0c;效果不错&#xff0c;团队也认可。但当你想把它拿回实验室做进一步微调、…

作者头像 李华
网站建设 2026/4/18 5:31:38

番茄小说下载器终极指南:5分钟打造个人离线图书馆

番茄小说下载器是一款功能强大的开源工具&#xff0c;专为需要离线阅读番茄小说内容的用户设计。通过智能下载技术和多格式支持&#xff0c;帮助用户建立专属的私人书库&#xff0c;实现真正的阅读自由。无论身处网络不稳定的环境&#xff0c;还是需要长期保存珍贵作品&#xf…

作者头像 李华