- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
这是我从一些旧的 Java 代码创建的一个简单的 C 程序(我的第一个 C 程序,所以很好 ;))。这比相应的 Java 代码运行得快得多,但 Java 允许我在它崩溃之前更精确(我也在 Java 中使用 longs)。
令我惊讶的是,直到输入超过 170,000,000,Java 代码才崩溃。 C 代码无法处理超过 1,050,000 的任何内容。有什么建议可以让这个 C 代码在不需要一些疯狂的库的情况下运行得更好吗?谢谢!
#include <stdio.h>
#include <string.h> /* lets me use memset */
#include <stdlib.h> /* home of strtoull */
/* segfault 11 after 1047993 (Not anymore!!) */
unsigned long long getnext( unsigned long long x );
unsigned long long getnext( unsigned long long x )
{
if (x == 1) { return 1; }
if (x % 2 == 0) { return x/2; }
return (3 * x + 1);
}
int main(int argc, char *argv[])
{
int argind;
for ( argind = 0; argind < argc; argind++ )
{
unsigned long long intrange;
intrange = strtoull(argv[argind], NULL, 10);
/** Improper allocation of memory. Fixed directly below. Thanks Marcus!
* unsigned long long lengths[intrange+1];
* memset(lengths, 0, sizeof(lengths));
*/
unsigned long long *lengths= malloc((intrange+1) * sizeof(unsigned long long)); /* ptr points to mem. location of lengths array. */
memset(lengths, 0, (intrange+1) * sizeof(unsigned long long));
unsigned long long longestlen[2];
unsigned long long seqindex;
unsigned long long origdex;
longestlen[0] = 0;
longestlen[1] = 0;
for (origdex = 2; origdex <= intrange; origdex++)
{
seqindex = origdex;
while ( seqindex > 1 )
{
lengths[ origdex ] += 1;
seqindex = getnext(seqindex);
if ( seqindex <= intrange )
{
if ( lengths[ seqindex ] > 0)
{
lengths[ origdex ] = lengths[ origdex ] + lengths[ seqindex ];
if ( lengths[origdex] > longestlen[1] ) { longestlen[0] = origdex; longestlen[1] = lengths[origdex]; }
seqindex = 1;
continue;
}
}
}
}
if(longestlen[0] > 0 ){ printf("Longest Collatz sequence for first %llu positive integers found at %llu with length %llu. \n", intrange, longestlen[0], longestlen[1]); }
}
return 0 ;
}
最佳答案
如果你让你的程序通过调试器运行(在我的例子中:
gcc -o collatz -g collatz.c
gdb --args collatz 2000000
$run
...segfault at memset(lengths,0,sizeof(lengths))...
),当您尝试访问长度时,您会发现您的段错误发生了!
关键是你为数组做动态内存分配是错误的;这在 C 中有点棘手(这就是为什么我通常建议来自其他语言的人学习现代 C++ 而不是 C)。
你应该这样做
unsigned long long *lengths = malloc(...);
给你新分配的内存。
此外,sizeof(lengths)
是错误的,因为那将是指向数组开头地址的指针的大小。请改用 sizeof(unsigned long long)
。当然,您的代码必须读取 memset(lengths, 0, sizeof(unsigned long long)*(intrange+1))
以设置 intrange+1
倍数unsigned long long
占 0
字节的字节数。
有关malloc
的详细信息,如果您在具有man
的系统上,则可以使用man malloc
;通常,您必须在使用后“释放”使用 malloc
分配的内存。在你的情况下,程序终止时它会自动完成,但对于更复杂的软件,不会调用 free(ptr)
你通过 type *ptr = malloc(.. .)
在您不再需要该内存之后就是内存泄漏。
同样,这是一个非常典型的 C 语言问题。如果您使用 C++ 编写代码,您将能够使用诸如 std::vector
之类的东西来为您提供具有自动构造和值填充功能的可变大小数组,而几乎不会对性能造成任何影响,它将在离开声明它的范围时自动释放。
关于java - Collatz 和其他序列 : how to get more precision easily and avoid segfault?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30818027/
我正在阅读 Python 文档以真正深入了解 Python 语言,并遇到了 filter 和 map 函数。我以前使用过过滤器,但从未使用过映射,尽管我在 SO 上的各种 Python 问题中都见过这
当我尝试打印 BST 的级别顺序时,这个问题提示了我。 这是一个 Pre-Order Sequence: 4, 1, 2, 3, 5, 6, 7, 8 In_order Sequence : 1, 2
我的代码在 main(序列测试;)的第一行出现错误,指出它是对 sequence::sequence() 的 undefined reference 。我无法更改 main 中的代码。有谁知道我该如何
这可能很简单,但我在通常的 latex 指南中找不到任何相关内容。在这句话中: {\em hello\/} “\/”的目的是什么? 最佳答案 这就是所谓的斜体校正。其目的是确保斜体文本后有适当的间距。
当我从 Postgresql 表中删除所有记录,然后尝试重置序列以在插入时开始一个编号为 1 的新记录时,我得到不同的结果: SELECT setval('tblname_id_seq', (SELE
在版本10.0.3中,MariaDB引入了一种称为序列的存储引擎。 其ad hoc为操作生成整数序列,然后终止。 该序列包含正整数,以降序或升序排列,并使用起始,结束和递增值。 它不允许在多个查询中
如何在 Groovy 中获取给定数字的序列,例如: def number = 169 // need a method in groovy to find the consecutive number
基本上,如果这是 .NET,它看起来像这样: ISomething { string A { get; } int B { get; } } var somethings = new List
说以下代码部分(同一块): A <= 1 A <= 2 变量 A 总是被赋值为 2 吗?还是会出现竞争条件并分配 1 或 2? 我对非阻塞赋值的理解是,由硬件在 future 分配变量 A,因此它可能
在运行 WiX 设置时,我正在寻找操作列表及其顺序。不知何故,官方网站似乎没有提供任何信息。 基本问题是我想正确安排我的自定义操作。通常我需要使用 regsvr32.exe 注册一个 DLL,而这只能
F#初学者在这里 我想创建一个类型,它是具有至少一个元素的另一种具体类型(事件)的序列。任何其他元素都可以在以后随时添加。通常在 C# 中,我会创建一个具有私有(private) List 和公共(p
作为构建过程和不断发展的数据库的一部分,我试图创建一个脚本,该脚本将删除用户的所有表和序列。我不想重新创建用户,因为这将需要比所允许的更多的权限。 我的脚本创建了一个过程来删除表/序列,执行该过程,然
我想恢复两个向量的第一个日期和相同向量的第二个日期之间的日期序列,.... 这是一个例子: dates1 = as.Date(c('2015-10-01', '2015-03-27', '2015-0
这个问题已经有答案了: sql ORDER BY multiple values in specific order? (12 个回答) 已关闭 9 年前。 我有一个 sql 语句,我想要ORDER
我想恢复两个向量的第一个日期和相同向量的第二个日期之间的日期序列,.... 这是一个例子: dates1 = as.Date(c('2015-10-01', '2015-03-27', '2015-0
在用java编写代码时,我需要用“],[”分割字符串。下面是我的代码。 try (BufferedReader reader = new BufferedReader(new InputStreamR
这个问题已经有答案了: Project Euler Question 14 (Collatz Problem) (8 个回答) 已关闭 9 年前。 我正在尝试查找数字的 Collatz 序列。以下
我有一个例程函数process_letter_location(const char& c, string &word)。 在我的 main 中,我声明了一系列字符串变量,如下所示: string s
我需要找到最长的多米诺骨牌链,给定一组 12 个随机挑选的多米诺骨牌。我已经递归地生成了多米诺骨牌的所有可能性(使用 0 到 12 的面值有 91 种可能性)。多米诺骨牌由一 block “砖 blo
我有这个数据结构 Seq,它继承了类 vector 但有一些额外的功能。使用这个数据结构 Seq 我有这个预定义的数据结构: typedef Seq > MxInt2d; 我现在想要一个包含多个 Mx
我是一名优秀的程序员,十分优秀!