c程序中的分段错误

时间:2015-03-21 20:28:43

标签: c

尝试执行此简单的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]);
    }

}

2 个答案:

答案 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);