python分苹果问题_给大家分享一个「Python算法题」分苹果

python分苹果问题_给大家分享一个「Python算法题」分苹果今天刷到一道算法题,分享一下果园里有堆苹果,N(1<N<9)只熊来分。第一只熊把这堆苹果平均分为N份,多了一个,它把多的一个扔了,拿走了一份。第二只熊把剩下的苹果又平均分成N份,又多了一个,它同样把多的一个扔了,拿走了一份,第三、第四直到第N只熊都是这么做的,问果园里原来最少有多少个苹果?可以先尝试一下再往下看(N=5的时候,答案是3121)。先简单分析一下这道题目,假设当第k个熊取完之后还有M个…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

今天刷到一道算法题,分享一下

果园里有堆苹果,N(1<N<9)只熊来分。第一只熊把这堆苹果平均分为N份,多了一个,它把多的一个扔了,拿走了一份。第二只熊把剩下的苹果又平均分成N份,又多了一个,它同样把多的一个扔了,拿走了一份,第三、第四直到第N只熊都是这么做的,问果园里原来最少有多少个苹果?

可以先尝试一下再往下看(N=5的时候,答案是3121)。

先简单分析一下这道题目,假设当第k个熊取完之后还有M个苹果,按照题目的意思,M除以N的余数恰好是1,那么第k+1只熊可以拿到(M-1)/N个苹果,第k只熊取之前有MN/(N-1)+1个苹果。 换句话说,这堆苹果满足一个性质,对于每一只熊,取之前取之后的苹果数除以N都余1,取之后的苹果数整除(N-1)*。

这样考虑的话,我们可以从最后一只熊开始向前倒推总的苹果数num,最后一只熊取走了N份苹果中的1份,所以剩下的苹果一定为N-1的倍数,所以num初始值一定为N-1的倍数。

把num初值为 N-1之后,开始倒推,上一只熊取之前的苹果数为num = num + num/(N-1)+1,再判断这个数字能否被N-1整除,若可以,继续向前倒推,若不能,说明num不满足条件,将num初值更新为2(N – 1),重复上述过程,若nun不满足条件,再设置为3(N-1),依次类推,直到循环中的num都能被N-1整除,这时候的num为满足条件的最小值,可能说的不是很清楚,直接看代码

8595f7f7840f

给大家分享一个「Python算法题」分苹果

再仔细分析一下这个题目,如果把每只熊取之前的苹果数记做一个序列

8595f7f7840f

给大家分享一个「Python算法题」分苹果

根据之前的分析,倒数第k次取之前的苹果数是倒数k+1次取之前的苹果扔掉一个再取走一份后剩下的,所以有关系式:

8595f7f7840f

给大家分享一个「Python算法题」分苹果

同时倒数第一只熊取之前的苹果数满足条件:

8595f7f7840f

给大家分享一个「Python算法题」分苹果

这里|表示整除,因为它需要扔掉一个然后分成N份。换种表示方式可以写成

8595f7f7840f

给大家分享一个「Python算法题」分苹果

综合到一起,所有的条件可以描述为

8595f7f7840f

给大家分享一个「Python算法题」分苹果

有没有感觉很熟悉,这不就是高中的数列递推公式?把通项公式求出来就完事了,根据上面的递推式,有

8595f7f7840f

给大家分享一个「Python算法题」分苹果

最后得到

8595f7f7840f

给大家分享一个「Python算法题」分苹果

因为xN必须是整数,所以m取值不能任意,有一定的限制,实际上已经非常明确了,要使得xN是整数,只要让m的取值恰好可以消掉中式子的分母就可以了,最终可以得到

8595f7f7840f

给大家分享一个「Python算法题」分苹果

其中

8595f7f7840f

给大家分享一个「Python算法题」分苹果

这样我们实际上求出了所有满足条件的苹果数量,如果只要最小数量,让t=1就可以啦,最终得到

8595f7f7840f

给大家分享一个「Python算法题」分苹果

这样代码就变得非常非常非常简单。

8595f7f7840f

给大家分享一个「Python算法题」分苹果

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/183461.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月10日 下午5:36
下一篇 2022年10月10日 下午5:36


相关推荐

  • onmousemove鼠标截取

    onmousemove鼠标截取mouseover 鼠标截取

    2026年3月26日
    2
  • 【SCOI补全记】SCOI2016 bzoj4567-4572

    【SCOI补全记】SCOI2016 bzoj4567-4572T1:背单词(bzoj4567)题解代码T2:幸运数字(bzoj4568)题解代码T3:萌萌哒(bzoj4569)T4:妖怪(bzoj4570)T5:美味(bzoj4571)题解代码T6:围棋(bzoj4572)T1:背单词(bzoj4567)题解关键词:trie树贪心题意有些难懂,简单解释一下。对于在位置xxx的单词:…

    2022年7月26日
    9
  • 对角化可逆矩阵怎么求_正交矩阵一定可逆吗

    对角化可逆矩阵怎么求_正交矩阵一定可逆吗1矩阵对角化方法摘要:本文给出了一种不同于传统方法的矩阵对角化方法,利用矩阵的初等变换,先求出矩阵的特征根与特征向量,接着再判断矩阵是否可对角化。关键词:矩阵特征根特征向量对角化TheMethodsoftheDiagonalizationoftheMatrixgAbstract:Inthispaper,themethodofthediagonalizationoft…

    2025年6月15日
    5
  • leanback android,Android TV Leanback (五)(使用leanback创建UI)

    leanback android,Android TV Leanback (五)(使用leanback创建UI)创建浏览布局 leanback 库的 BrowseFragme 允许您创建一个主要布局 以最少的代码浏览媒体项的类别和行 代码示例如下 android id id main frame android layout width match parent android layout height match parent gt android name com example andro

    2026年3月19日
    2
  • 测试工具之 LoadRunner & WinRunner

    测试工具之 LoadRunner & WinRunner业界知名的 LoadRunner WinRunner TestDirector 和 QuickTestPro 等自动化测试工具出自 Mercury 公司 Mercury 是全球企业测试市场的绝对领导者 我们来了解一下 WinRunner 和 LoadRunner 下面就安装和使用上 我们一起来学习一下这两个工具 nbsp 1 WinRunnerMer 是行业标准的用于企业 I

    2026年3月16日
    2
  • iframe高度自适应的6个方法

    iframe高度自适应的6个方法原文链接 http caibaojian com iframe adjust content height htmlJS 自适应高度 其实就是设置 iframe 的高度 使其等于内嵌网页的高度 从而看不出来滚动条和嵌套痕迹 对于用户体验和网站美观起着重要作用 如果内容是固定的 那么我们可以通过 CSS 来给它直接定义一个高度 同样可以实现上面的需求 当内容是未知或者是变化的时候 这个时候又有几种

    2026年3月19日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号