当前位置: 首页 > news >正文

(新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); } }
http://www.gsyq.cn/news/106398.html

相关文章:

  • 【分析式AI】-带你秒弄懂决策树与随机森林
  • 大模型Agent面试精选15题(第四辑)-Agent与RAG(检索增强生成)结合的高频面试题
  • 中国科学技术大学LaTeX论文模板参考文献格式完整解析与实战指南
  • LeakCanary如何避免误报内存泄漏?
  • LeakCanary 检测内存泄漏的核心原理
  • Android Studio开发APP接入ACE-Step音乐API:移动端创作新体验
  • 终极右键菜单优化利器:ContextMenuManager完全使用手册
  • 3分钟学会原神帧率解锁:告别卡顿的终极优化指南
  • Driver Store Explorer终极指南:轻松管理Windows驱动存储库
  • 22、IIR滤波器的逐步设计
  • 11、Z变换与差分方程求解全解析
  • 13、离散时间傅里叶变换与离散傅里叶变换详解
  • 4、深入理解BPF Maps:创建、操作与应用
  • 5分钟精通!ColorUI导航组件让界面切换效率提升300%
  • ImageToSTL:零基础图片转3D模型完整教程
  • 12.15 - 两数之和 两个浮点类型不可以直接判断相等以及解决方案
  • PlayCover终极指南:在Apple Silicon Mac上运行iOS游戏的完整教程
  • 中国科学技术大学ustcthesis模板参考文献格式最新完整指南:快速解决本科论文排版问题
  • Wan2.2-T2V-A14B助力内容创作者告别传统剪辑?
  • MOOTDX股票数据分析实战指南:从入门到精通掌握通达信数据接口
  • Ascend C内存越界访问的“侦探术“:从错误地址到Buffer/Tensor安全
  • 17、深入探究Linux USB调试与测试方法
  • 18、Linux USB 设备测试与回归工具详解
  • 火山引擎推出Qwen-Image-Edit-2509专属GPU算力套餐
  • Wan2.2-T2V-A14B时序连贯性优化背后的黑科技
  • Windows触控板三指拖拽终极指南:从零配置到专家级技巧
  • 百度搜索不到Qwen-Image?教你从HuggingFace镜像网站快速获取
  • GitHub镜像网站加速LLama-Factory依赖库安装,提升构建速度5倍以上
  • 基于ACE-Step镜像的AI音乐创作实战:从零开始生成你的第一首曲子
  • HuggingFace镜像网站资源推荐:Qwen-Image使用体验分享