尝试执行此简单的c排序程序时出现分段错误 我是C语言的新手。你能解释一下我为什么会出现分段错误
#include<stdio.h>
int main(void)
{
int prev,next,result,total_number;
int i,j=1,b;
int a[i];
printf("Number of values to be entered");
scanf("%d",total_number);
printf(" enter the values \n");
for(i=0;i<=total_number-1;i++)
{
printf(" enter the values \n");
scanf("%d",a[i]);
}
for(i=0;i<=total_number-2;i++)
{
for(j=1;j<=total_number-1;j++)
{
if(a[i]>a[j])
{
b=a[i];
a[i]=a[j];
a[j]=b;
}
else
{
break;
}
}
}
for(i=0;i<total_number-1;i++)
{
printf("The numbers are %d",a[i]);
}
}
答案 0 :(得分:3)
分段错误是由以下行引起的:
scanf("%d",total_number);
您错过了(&amp;)运营商的地址,应该是这样的:
scanf("%d",&total_number);
此行中也缺少运营商:
scanf("%d",a[i]);
您可以在glibc manual:
中找到有关scanf的更多详细信息scanf和printf之间的另一个区别是你必须记住提供指针而不是立即值作为scanf的可选参数;读取的值存储在指针指向的对象中。即使是有经验的程序员也偶尔会忘记这一点,所以如果你的程序遇到了与scanf有关的奇怪错误,你可能需要仔细检查一下。
但是你的代码中还有其他微妙的错误:array [i]中的int i未初始化的事实导致未定义的行为,即任何事情都可能发生。您可以使用malloc为数组分配空间,但简单的重新排序就足够了:
scanf("%d",&total_number);
int a[total_number];
使用用户输入来分配数组。
最后,您似乎正在尝试实施插入排序算法,但逻辑略有缺陷:甚至纠正代码中的错误输入
1 3 5 0
得到&#34;命令&#34;到
1 5 3 0
但我不知道你要实施的是什么。如果您实际上是在尝试实现插入排序,可以使用insertion sort wiki文章中的pseucode来了解实现中缺少的内容。
答案 1 :(得分:2)
int a[i];
正在创建一个任意大小的数组,因为我没有初始化。
相反,一旦知道了total_number,就可以动态创建int数组的等价物。
int* a;
. . . snip . . .
/* once you know total_number */
a = (int*) malloc(total_number, sizeof(int));
/* you can use a with array notation as long as you stay in bounds */
a[i] = something;
/* don't forget to free a when you are done */
free(a);