- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个包含 100000 个元素(整数)的数组,我想使用快速排序对其进行排序。当我用随机数填充这个数组时它会起作用,但是当我像这样填充它时
for(i=0; i<size/2; i++)
{
tablica[i]= i;
}
for(i=size/2; i<size; i++)
{
tablica[i]=size-i-1;
}
我收到 SIGSEGV 信号,我的应用崩溃了。我确定我的快速排序功能没问题。当我用随机、升序或降序数字填充此数组时,一切正常,即使数组中有更多元素(如 100000000)。我这样初始化数组:
int *tablica = calloc(size, sizeof (int));
这是我的快速排序代码
void quicksort(int tab[], int lewy, int prawy)
{
int pivot = tab[(prawy+lewy)/2];
int p = prawy;
int l = lewy;
do
{
while (tab[l] < pivot)
{
l++;
}
while (tab[p] > pivot)
{
p--;
}
if (l <= p)
{
int temp = tab[l];
tab[l] = tab[p];
tab[p] = temp;
l++; p--;
}
} while (l <= p);
if(p>lewy)
{
quicksort(tab,lewy,p);
}
if(l<prawy)
{
quicksort(tab,l,prawy);
}
}
和主要功能的例子
int main()
{
srand(time(NULL));
int i;
int *tablica;
float start, stop, czas;
tablica = calloc(size, sizeof (int));
int *tab = calloc(size, sizeof (int));
for(i=0; i<size/2; i++)
{
tablica[i]= i;
}
for(i=size/2; i<size; i++)
{
tablica[i]=size-i-1;
}
start = clock();
quicksort(tablica,0,size-1);
stop = clock();
czas = (stop-start)/CLOCKS_PER_SEC;
free(tablica);
free(tab);
return 0;
}
最佳答案
I'm sure that my quicksort function is fine.
它可能是递归的,不是吗?您看到的很可能是堆栈溢出,这是由递归嵌套太深引起的。快速排序在这方面尤其薄弱,这取决于枢轴的选择和值的分布。
示例:大小为 8
的数组,按照您指定的方式填充:
0 1 2 3 3 2 1 0
让我们以第一个值作为基准,因此在分区之后我们可能会得到:
0|0|1 2 3 3 2 1
看看发生了什么?我们只设法将一个数字放入左侧部分。在正确的部分快速排序不会更好:
1 2 3 3 2 1
我们像以前一样以第一个为枢轴并进行划分:
1|1|2 3 3 2
等等。
在每一步中,您只需对 2 个元素进行排序(左侧部分的主元和单个元素)...因此,对于 100000 个数字的数组,您需要 50000 步才能对其进行排序。每一步都是递归调用。这对于(调用)堆栈来说太多了。
为了减轻出现这种模式的危险,您应该调整 choice of your pivot value .
来自添加的快速排序代码:
int pivot = tab[(prawy+lewy)/2];
您始终选择排序范围中间的值。在第一次迭代中,这将是 size/2 -1
,并且由于没有比该值更大的值(由于数组的初始化方式),右侧部分将(几乎)为空,从而导致与我上面显示的类似模式。
提示:只需尝试使用较小的代码(例如 8
),并在每次调用时打印快速排序正在处理的数组:
0, 1, 2, 3, 3, 2, 1, 0 // (1)
0, 1, 2, 0, 1, 2
0, 1, 2, 0, 1
0, 1, 1, 0 // (2)
0, 0 // right part from (2)
3, 3 // right part from (1)
( Ideone )
关于c - 对具有大量元素的数组进行排序时发出 SIGSEGV 信号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36345404/
这个问题是针对 Linux 提出的。使用 GCC 编译器。 如果 SIGSEGV(我的意思是通常会导致 SIGSEGV 的违规行为)发生在旨在捕获 SIGSEGV 的信号处理程序中,可以预期会有什么行
我正在构建一个 C++ 程序,我需要在其中处理 SIGSEGV 并且信号处理程序应该能够打印回溯。任何人都可以帮忙吗。 问候 最佳答案 获得 SIGSEV 回溯的最好方法是生成核心文件而不是打印回溯。
我有一个屏幕A,在执行了一些POST API任务后,我启用了一个按钮,然后单击按钮导航到屏幕B。当Reaction Native应用程序冻结并崩溃时,崩溃会随机发生。从其他屏幕导航到屏幕B也不是问题,
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我正在编写这个方法(C 语言),它应该为链表创建一个新节点。它在第一个 if (SIGSEGV 信号)之后的行崩溃 我正在调试该方法,因此后续行中可能会有更多错误,但目前我将感谢有关此特定行的任何观察
这是我的比较函数: int compareInts(const void *a, const void *b) { const int *pa = (const int*)a; con
我一直在研究一些有缺陷的代码,并想安装一个 SIGSEGV 处理程序来获取有关崩溃的更多信息。但是,我注意到我的处理程序没有被调用。 我一直在寻找原因,它似乎与损坏的堆栈指针值有关(它肯定没有被屏蔽)
我是编码新手。当我在 codecheff 中提交代码时,它给出“运行时错误(SIGSEGV)”。我不知道有什么问题请帮忙。提前致谢。 int call(int *x, int m) { int
CodeChef 问题: Shivam 是世界上最年轻的程序员,他只有 12 岁。 Shivam 正在学习编程,今天他正在编写他的第一个程序。 程序很简单,给定两个整数A和B,编写一个程序将这两个数字
我正在编写一个编程问题的解决方案。问题如下: Your program is to use the brute-force approach in order to find the Answer t
好吧,只是为了好玩,我正在研究埃拉托色尼筛。它最初运行良好,因此我寻求提高其运行时复杂性。现在,我不知道为什么,但我遇到了段错误。代码如下: #include #include int main(
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我正在创建一个简单的链表程序来插入和查看 LL 的元素。当我尝试插入第二个元素时,它给出 SIGSEV,但我不明白为什么?!! 请帮我指出问题: main.c: #include #includ
我试图提交此代码以解决 hackerearth 上的问题,但我得到了此 SIGSEGV 运行时错误。我读到了这个错误,但我无法让我的代码工作。有人说这是由于无效的内存引用、数组的动态初始化或数组索引超
我正在思考 leetcode 问题 167,但我的代码遇到了段错误 (SIGSEGV) 问题。下面是我的c代码,预期的答案是[1,3]。 #include #include /** * Return
我有一个在ARM平台上运行的多线程程序。在其中一个线程中,我将调用 system() 来运行某些 shell 命令。最近,我发现有时候,由system() fork 的子进程会以SIGSEGV终止。
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我很高兴知道为什么我遇到此错误 http://www.codechef.com/problems/AXR1P2在 codechef.com 中,我的代码是... #include #include i
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我正在使用 POSIX 套接字在 Android 上编写一些网络代码,但是当我调用 Sento 时,我收到了一个奇怪的 SIGSEGV(信号 11,代码 1)。我已经使用墓碑跟踪来确定它是哪一行,但坦
我是一名优秀的程序员,十分优秀!