news 2026/2/26 15:29:07

(新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/2/17 23:53:11

基于WebSocket实现实时图像生成:FLUX.1-dev模型前后端通信方案

基于WebSocket实现实时图像生成&#xff1a;FLUX.1-dev模型前后端通信方案 在AI内容生成日益普及的今天&#xff0c;用户不再满足于“输入提示词、等待结果”的静态交互模式。他们希望看到图像从模糊轮廓到细节丰富的演变过程——就像一位艺术家在画布上逐步勾勒作品。这种对“…

作者头像 李华
网站建设 2026/2/19 23:29:29

PyTorch安装与Qwen-Image部署全流程详解(附GPU优化技巧)

PyTorch安装与Qwen-Image部署全流程详解&#xff08;附GPU优化技巧&#xff09; 在生成式AI如火如荼的今天&#xff0c;图像创作已从“能否生成”转向“如何高效、稳定地生成高质量内容”。尤其在广告设计、数字艺术和电商配图等专业领域&#xff0c;用户不再满足于模糊或构图混…

作者头像 李华
网站建设 2026/2/23 16:53:48

浏览器串口助手终极指南:3分钟快速上手零安装串口调试

还在为复杂的串口调试工具安装而烦恼吗&#xff1f;波特律动串口助手作为一款创新的浏览器原生串口工具&#xff0c;让你告别繁琐的驱动配置&#xff0c;直接在浏览器中轻松管理串口设备&#xff01;无论是物联网开发、嵌入式调试还是蓝牙BLE连接&#xff0c;这款工具都能帮你快…

作者头像 李华
网站建设 2026/2/14 9:03:51

NPM Scripts集成LLama-Factory前端监控面板,实时查看训练状态

NPM Scripts集成LLama-Factory前端监控面板&#xff0c;实时查看训练状态 在大模型开发日益普及的今天&#xff0c;越来越多的团队和个人开发者希望快速微调一个属于自己的语言模型——无论是用于客服对话、内容生成&#xff0c;还是内部知识库问答。然而&#xff0c;传统训练流…

作者头像 李华