- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
如何找出某个数字的个位数(例如 3 power 2011
)。我应该使用什么逻辑来找到这个问题的答案?
最佳答案
对于基数 3:
3^1 = 3
3^2 = 9
3^3 = 27
3^4 = 81
3^5 = 243
3^6 = 729
3^7 = 2187
...
也就是说个位数字只有 4 种可能性,然后它会在同一个循环中重复出现。
在Euler's theorem的帮助下我们可以证明这适用于任何整数 n,这意味着它们的单位数字将在最多 4 个连续的指数之后重复。只看任意乘积的个位数相当于乘法取余数模10,例如:
2^7 % 10 = 128 % 10 = 8
还可以证明(并且非常直观)对于任意底数,任何幂的个位数将仅取决于底数本身的个位数 - 即 2013^2013 与 3 具有相同的个位数^2013。
我们可以利用这两个事实来提出一个极快的算法(感谢 help - 如果允许我可以提供一个更快的版本)。
想法是这样的:正如我们所知,对于任何数字 0-9 最多会有 4 种不同的结果,我们也可以将它们存储在查找表中:
{ 0,0,0,0, 1,1,1,1, 6,2,4,8, 1,3,9,7, 6,4,6,4,
5,5,5,5, 6,6,6,6, 1,7,9,3, 6,8,4,2, 1,9,1,9 }
这是 0-9 的可能结果,按顺序分成四组。现在的想法是求幂 n^a 到
i
4*i
(它是该特定数字的起始偏移量)off
(正如欧拉定理所述,我们只有四种可能的结果!)4*i
中加入off
得到结果现在为了使其尽可能高效,对基本算术运算应用了一些调整:
a % 4
等同于说 a&3
(屏蔽 1 和 2 位,形成余数 % 4)C中的算法:
static int table[] = {
0, 0, 0, 0, 1, 1, 1, 1, 6, 2, 4, 8, 1, 3, 9, 7, 6, 4, 6, 4,
5, 5, 5, 5, 6, 6, 6, 6, 1, 7, 9, 3, 6, 8, 4, 2, 1, 9, 1, 9
};
int /* assume n>=0, a>0 */
unit_digit(int n, int a)
{
return table[((n%10)<<2)+(a&3)];
}
初始声明的证明
通过观察,我们注意到 3^x 的个位数每四次方重复一次。声称这适用于任何整数。但这实际上是如何证明的呢?事实证明,使用模块化算法非常容易。如果我们只对个位数感兴趣,我们可以执行模 10 的计算。这相当于说 4 个指数后的个位数循环或说
a^4 congruent 1 mod 10
如果这个成立,那么举例
a^5 mod 10 = a^4 * a^1 mod 10 = a^4 mod 10 * a^1 mod 10 = a^1 mod 10
也就是说,a^5 产生与 a^1 等相同的个位数。
来自 Euler's theorem我们知道
a^phi(10) mod 10 = 1 mod 10
其中 phi(10) 是 1 到 10 之间与 10 互质的数(即它们的 gcd 等于 1)。 < 10 与 10 互质的数字是 1、3、7 和 9。所以 phi(10) = 4 这证明确实 a^4 mod 10 = 1 mod 10
。
要证明的最后一个声明是,对于基数 >= 10 的幂运算,只需查看基数的个位数就足够了。假设我们的基数是 x >= 10,那么我们可以说 x = x_0 + 10*x_1 + 100*x_2 + ...(基数 10 表示)
使用模块化表示很容易看出这一点
x ^ y mod 10
= (x_0 + 10*x_1 + 100*x_2 + ...) ^ y mod 10
= x_0^y + a_1 * (10*x_1)^y-1 + a_2 * (100*x_2)^y-2 + ... + a_n * (10^n) mod 10
= x_0^y mod 10
其中 a_i 是包含 x_0 次幂但最终不相关的系数,因为整个乘积 a_i * (10 * x_i)^y-i 将被 10 整除。
关于algorithm - 怎样用最简单的方法求某次幂的个位数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7214419/
我制作手机游戏,但我想为我的社交游戏制作一些简单的基于浏览器的客户端,以便我们可以更轻松地调试。最简单的引擎是什么? 我研究了一些 HTML5 引擎和 GWT,但我想听听社区的意见。我正在寻找一种能够
有一个有趣的例子,有人设法为一个只占用 1kb 的论坛创建了一个 PHP 脚本:http://www.nerdparadise.com/blogs/blake/6034/ 我想知道是否有类似的小脚本可
首先我要吐槽一下,看程序的过程中遇见了yield这个关键字,然后百度的时候,发现没有一个能简单的让我懂的,讲起来真tm的都是头头是道,什么参数,什么传递的,还口口声声说自己的教程是最简单的,最浅显易
我的proguard配置太糟糕了,我的游戏崩溃了,而且似乎不正常。在我弄清楚到底哪里出了问题之前,最简单,最安全的配置用于全部安装是什么?有没有办法使它仅更改变量名?或者只是混淆代码以使其更难阅读而不
我正在重构一些 C# 代码,其中一部分是重做一些引用,因为我们正在完全重做文件夹结构。我想做的就是进入 .csproj 或 .sln 文件并修改路径。 然而,一些引用文献有类似的路径 "../../.
免责声明:这是一个理论问题,目的是增加我的理解。我知道我总是可以使用像 JSON 库这样的工具来解决问题。 假设我想创建一个逗号分隔的值列表,这些值本身可能包含逗号。这些逗号需要先转义。假设我使用 .
我对编程完全陌生,我选择 Delphi 作为我想学习的编程语言。 我基本上想构建使用套接字填写和提交 Web 表单的工具,并且我希望它们也是多线程的。 我希望它们功能丰富且性能正确。 我并不急于这样做
我正在构建一个协作创作工具,该工具允许用户共同编辑信息空间,该信息空间是节点和链接的可视化。一个客户端应用程序中所做的更改需要反映到所有其他客户端中。由于它是可视化的,因此可能需要经常更新潜在的大数据
作为一家专门开发自定义 CMS 的公司,我们被要求在下一个项目中部署开源 CMS。 我们可以自由选择系统。对于熟悉 PHP5 中的 MVC 模型和 OOP 的团队,您会推荐什么? 有人告诉我Drupa
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我完全是 Ember.js 菜鸟,需要了解后端注意事项,目前似乎很少有教程涵盖。对于快速原型(prototype)设计,最简单/最简单的后端设置是什么?我看到了一些 ember-rails 教程,但是
我正在寻找这种最简单、最简单的方法来启动 Java Web 服务。我曾经使用 Axis-1-on-Tomcat,但是对于 Axis 2,它变得太厚了。我正在寻找的一些偏好: 低内存占用 - 一个包含最
我多年来一直使用旧版 openGL 和 cocoa,但现在我正在努力过渡到 openGL 3.2。互联网上有几个例子,但它们都太复杂了(许多甚至在 XCode 5.1 下不再编译)。有人可以编写一个最
我正在构建一个简单的应用程序,它应该将开关/支票簿的状态存储 7 天。我遇到的唯一问题是我用来构建所述应用程序的网站不适合手机上的本地存储。没有通过本地存储或链接到在线数据库来存储开关/支票簿状态的良
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 7 个月前。 Improv
有时我需要 1 个用户类型元素的集合(或任何其他容器)并以这种方式创建它们: boost::assign::list_of(typeVariable).convert_to_container >()
我的页面上有一个 DropDownList 和一个 TextBox。当用户在 DropDownList 中选择“其他”选项时,我想在其右侧显示一个文本框。我不想使用传统的回发技术。我希望这种交互是在客
说到编码,我还很年轻,而且我听说过很多关于组织的事情。有些使用部分,有些使用 div,有些使用 div 作为按钮,其他使用 css 中的输入来更改它。作为一个喜欢让他的代码干净、简单易懂但又正确的人,
我需要将带有变量项的 ContentValues 转换为 JSON 字符串,我可以将其保存到数据库中,并在以后用作 HTTP 请求的正文。网络上的所有内容都只会以相反的方向进行转换。 最佳答案 每当您
我的电脑上安装了 Python 3.7。想用tensorflow,发现基本不支持3.7,所以想(也)安装Python 3.6。 关于如何做到这一点有什么建议吗?我是否必须卸载 3.7 并将其替换为 3
我是一名优秀的程序员,十分优秀!