- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
有一个表达式:[x/2] + y + x * y,x和y都是正整数,[x/2]表示向下取整,比如[3/2] = 1。这个表达式不能表示正整数,例如1、3。现在的问题是如何快速找出前40个数字?
当x = 1时,表达式为2*y,所以这个数一定不能是偶数。当y = 1时,表达式为[x/2] + x + 1,不包括3*n。然后我尝试如下:
int64_t givean( int n )
{
if( n == 1 ) return 1;
if( n == 2 ) return 3;
int i = 3;
int count = 2;
while( true ){
int64_t m = i * 3;
bool ok = true;
for( int x = 3; x <= ( 2*m - 2 ) / 3; x++ ){
if( ( x / 2 + x + 1 ) >= m ){
ok = false;
}
if( !( ( m - x/2 ) % ( x + 1 ) ) ){
ok = false;
break;
}
}
if( ok && ++count == n ){
return m;
}
i += 2;
}
}
可以快速找到前7个号码,找到第8个号码大约需要2分钟...前 8 个数字是:
1
3
15
63
4095
65535
262143
1073741823
有没有其他高性能算法可以解决这个问题?
最佳答案
这个非常无辜的问题被证明是非常棘手的。让我们分别看看 x
奇数和 x
偶数的情况。
如果x
是奇数,写x = 2k - 1
一些正整数k
。那么,我们有
n = (k-1) + y * 2k = 2ky + k - 1 = y(2k+1) - 1
注意y
是任意正整数,2k+1
是任意大于1的奇数。表达式y*(2k+1)
因此可以生成任何 具有奇数质因数的整数。因此,如果 n+1
有一个奇数质因数,则它有一个解,所以为了使它成为一个非解,n+1
必须是 1 (根本没有质因数)或二的幂。由于 n+1
是非法的(它会使 n
为 0,这不会发生,因为 x
和 y
是正整数),我们得出结论,所有非解决方案 n
必须有 n+1
是二的幂。
因此,对于某个正整数 m
,我们可以将所有非解写成 2^m-1
。
现在让我们看一下 even x
的情况。我们有
n = 2^m-1 = k + y * (2k+1) = k + 2ky + y
看2n+1
:
2n+1 = 2^(m+1)-1 = 2k + 4ky + 2y + 1 = (2k + 1)(2y + 1)
2k+1
和 2y+1
是任意奇数。因为 2n+1
总是奇数,所以我们得出结论 2n+1
一定是合数。每个解决方案(对于 x
甚至)都必须具有这种形式。因此,n
是无解当且仅当 n+1
是 2 的幂,并且 2n+1
是素数。
事实上,这意味着 2n+1
是梅森素数,因此前 40 个非解对应于前 40 个梅森素数(给定梅森素数 Mp
,对应的非解为(Mp-1)/2
)。
找到前 40 个 Mersenne 素数的最快算法是上网询问。 (说真的——找到梅森素数是一项艰苦的工作;第 50 个梅森素数甚至还不知道!)前 42 个梅森素数的指数由 OEIS A000043 给出。 :
1 2
2 3
3 5
4 7
5 13
6 17
7 19
8 31
9 61
10 89
11 107
12 127
13 521
14 607
15 1279
16 2203
17 2281
18 3217
19 4253
20 4423
21 9689
22 9941
23 11213
24 19937
25 21701
26 23209
27 44497
28 86243
29 110503
30 132049
31 216091
32 756839
33 859433
34 1257787
35 1398269
36 2976221
37 3021377
38 6972593
39 13466917
40 20996011
41 24036583
42 25964951
因此,例如,第 40 个无解是 2^(20996011-1)-1,这是一个非常大的数字。
关于algorithm - 求 [x/2] y x*y 不能表示的正整数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18200336/
我有一个加号/减号按钮,希望用户不能选择超过 20 个但不知道如何让它工作。我尝试使用 min="1"max="5 属性,但它们不起作用。这是我的代码和一个 fiddle 链接。https://jsf
我正在尝试复制顶部底部图,如示例 here但它没有正确渲染(紫色系列有 +ve 和 -ve 值,绿色为负值)留下杂乱的人工制品。我也在努力创建一个玩具示例来复制这个问题,所以我希望尽管我缺乏数据,但有
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭 6 年前。 社区去年审查了是
这个问题在这里已经有了答案: Adding two positive integers gives negative answer.Why? (4 个答案) 关闭 5 年前。 我遇到了一个奇怪的问题
有谁知道如何将字符串值类型 -4,5 或 5,4 转换为 double -4.5 或 5.4? 最佳答案 只需使用 Double.parseDouble(Locale, String); 糟糕,我很困
我正在尝试根据 TextBlob 分类插入一个仅包含“正”或“负”字符串的新数据框列:对于我的 df 的第一行,结果是 ( pos , 0.75, 0.2499999999999997)我想要' 正
我对 VBA 非常陌生,无法理解如何在一个循环中完成 2 个任务。我非常感谢您的帮助。 我已经能够根据第 3 列中的数据更改第 2 列中的数值,但我不明白如何将负值的字体更改为红色。 表格的大小每月都
欢迎, 我正在使用 jquery 通过 POST 发送表单。 这就是我获得值(value)的方式。 var mytext = $("#textareaid").val(); var dataStrin
double d = 0; // random decimal value with it's integral part within the range of Int32 and always p
我有这个字符串: var a='abc123#xyz123'; 我想构建 2 个正则表达式替换函数: 1) 用 '*' 替换所有确实有 future '#'的字符(不包括'#') 所以结果应该是这样的
我正在使用 DialogFragment。当用户从 Gmail 平板电脑应用程序的屏幕与下面示例图片中的编辑文本进行交互时,我希望正面和负面按钮保持在键盘上方。 在我的尝试中不起作用,这是我的 Dia
从组装艺术一书中,我复制了这句话: In the two’s complement system, the H.O. bit of a number is a sign bit. If the H.O
是否有更好更优雅的方法来实现下面的简单代码(diffYear、A 和 B 是数字): diffYear = yearA - yearB; if (diffYear == 0) { A = B
我正在设计一种语言,并尝试确定 true 应该是 0x01 还是 0xFF。显然,所有非零值都将转换为 true,但我正在尝试确定确切的内部表示。 每种选择的优点和缺点是什么? 最佳答案 没关系,只要
在我的 dialogfragment 类的 OnCreateDialog 中,我正在这样做: AlertDialog.Builder builder = new AlertDialog.Builder
这个问题在这里已经有了答案: Resolving ambiguous overload on function pointer and std::function for a lambda usin
我偶然发现了一个奇怪的 NSDecimalNumber 行为:对于某些值,调用 integerValue、longValue、longLongValue 等,返回意想不到的值(value)。示例: l
这个问题在这里已经有了答案: Resolving ambiguous overload on function pointer and std::function for a lambda using
我有这个正则表达式来测试用户输入是否有效: value.length === 0 || value === '-' || (!isNaN(parseFloat(value)) && /^-?\d+\.
我想用高斯混合模型拟合数据集,数据集包含大约 120k 个样本,每个样本有大约 130 个维度。当我使用 matlab 执行此操作时,我运行脚本(簇号为 1000): gm = fitgmdist(d
我是一名优秀的程序员,十分优秀!