c - 进程返回 - 1073741819 (0xC0000005)

标签 c matrix

我是 C 初学者。我遇到了这个错误,但我不知道如何修复它。我正在使用 Code:blocks 和 GNU GCC 编译器。这是一个简单的矩阵,必须使用 Shaker 排序进行排序。在我完成这项工作之前我无法继续。请大家帮帮我。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main()
{
    srand(time(NULL));
    int r=11, s=23, m[r][s], i, j, pom;

    printf("Generated matrix:\n\n");
    for(i=0;i<r;i++)
    {
        for(j=0;j<s;j++)
        {
            m[i][j]=rand()%100;
            printf("%3d", m[i][j]);
        }
        printf("\n");
    }

    i=0;
    j=0;
    do{
        if(m[i][j]>=m[i+1][j+1])
        {
            pom=m[i+1][j+1];
            m[i+1][j+1]=m[i][j];
            m[i][j]=pom;
        }

        if(j==s)
        {
            i++;
            j=0;
        }

        if(i==r&&j==s)
            break;
        j++;
    }while(1);

    for(i=0;i<r;i++)
    {
        for(j=0;j<s;j++)
        {
            m[i][j]=rand()%100;
            printf("%3d", m[i][j]);
        }
        printf("\n");
    }

    printf("\n\n");
    return 0;
}

编辑:

是的,伙计们,我完全错了。现在我不再收到此错误,但我不明白为什么我无法获得 m[r][s] 的最高数字。我总是得到完全相同的矩阵。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main()
{
    srand(time(NULL));
    int r=11, s=23, m[r][s], i, j, pom;

    printf("Generated matrix:\n\n");
    for(i = 0;i<r;i++)
    {
        for(j = 0;j<s;j++)
        {
            m[i][j] = rand()%100;
            printf("%3d", m[i][j]);
        }
        printf("\n");
    }
    printf("\n\n");
    i=0;
    pom=0;

    for(j=0;j=s;j++){
        if(m[i][j]>=m[i][j+1])
        {
            pom = m[i][j+1];
            m[i][j+1] = m[i][j];
            m[i][j] = pom;
        }

        if(i==r&&j==s)
            break;

        if(j==s)
        {
            i++;
            j=0;
        }
    }

    for(i = 0;i<r;i++)
    {
        for(j = 0;j<s;j++)
        {
            printf("%3d", m[i][j]);
        }
        printf("\n");
    }

    printf("\n\n");
    return 0;
}

最佳答案

您仍然在第 25 行包含基本错误:

// for(j=0;j=s;j++){

应该是:

for(j=0;j<s;j++){

在启用警告的情况下进行编译会立即披露此错误。每当您使用 gcc 编译代码时,最小值 都应该启用 -Wall -Wextra 警告。他们会节省你很多时间。示例:

gcc -Wall -Wextra -o bin/mtrxerr mtrxerr.c

仅纠正该错误,提供以下输出,其中矩阵按应有的方式更改。但是,您的排序仍然需要额外的工作。以下是输出示例:

输出:

$ ./bin/mtrxerr
Generated matrix:

 69 41 30 55 44 78 67 30 81 14 92 62 21 91 66 21 28 98 69 30 90 43 57
 12 35 85 21 49 45 31 40 14 24 70 22 68  0 89 50 81 56 42 44 77 33 62
 98 14 61 19 96  3 14 54 15 50 91 88 51 36 71 91 50 95 62 24 15 62 66
 66 96 22  8 40 51 94 54  1  8 67 21  4 70 35 10 37 85  1 78 36 37 49
 80 40 97 42 64 12 56 30 78 52  4 39 44 55 85 51 57 93 18 78 49 41 65
 60 78 51 13 56 39 51 58 19 91 55 13  7 67 22 90 98 74 94 89 71  2 74
 22 59 19 92 89 68 33 54 80 12 57 94 20 49 97 78 20 40 33 34 47 53  8
 89  3 82 84 92  5 38 66 79 97 85 72 38  5 57 44 38 21  2 84 42  3 81
 72 23 21  6  9 20 11 17 10 14 52 46  6  9 84 24 89 33 61 13 71 66 70
 67 56 92 69 40 86 24 21 58  0 94 16 61 15 27 79 77 93 83 23 99 92 59
 75 33 92 36 46 15 55 69 82 11 13  4 52 99 28 73 57 80 68 26 42 35 53


 41 30 55 44 69 67 30 78 14 81 62 21 91 66 21 28 92 69 30 90 43 57 12
 98 35 85 21 49 45 31 40 14 24 70 22 68  0 89 50 81 56 42 44 77 33 62
 98 14 61 19 96  3 14 54 15 50 91 88 51 36 71 91 50 95 62 24 15 62 66
 66 96 22  8 40 51 94 54  1  8 67 21  4 70 35 10 37 85  1 78 36 37 49
 80 40 97 42 64 12 56 30 78 52  4 39 44 55 85 51 57 93 18 78 49 41 65
 60 78 51 13 56 39 51 58 19 91 55 13  7 67 22 90 98 74 94 89 71  2 74
 22 59 19 92 89 68 33 54 80 12 57 94 20 49 97 78 20 40 33 34 47 53  8
 89  3 82 84 92  5 38 66 79 97 85 72 38  5 57 44 38 21  2 84 42  3 81
 72 23 21  6  9 20 11 17 10 14 52 46  6  9 84 24 89 33 61 13 71 66 70
 67 56 92 69 40 86 24 21 58  0 94 16 61 15 27 79 77 93 83 23 99 92 59
 75 33 92 36 46 15 55 69 82 11 13  4 52 99 28 73 57 80 68 26 42 35 53

您已在评论中被告知排序算法将需要嵌套循环。查看您的排序例程并纠正逻辑。例程的示例 Cocktail (shaker) Sort可以在网络上的许多地方找到。另一个例子是:Cocktail Sort Algorithm or Shaker Sort Algorithm

修复排序例程后,如果您仍然遇到问题,请发表评论,我们将很乐意提供额外的帮助。

关于c - 进程返回 - 1073741819 (0xC0000005),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27029358/

相关文章:

c - OpenSSL GFp 功能在替代 GF2m 功能方面是否缓慢下降?

c - C中两个二维数组相加

c# - 旋转矩阵给定角度和 X、Y、Z 中的点

c - 如何在循环中求和?并将其传递给另一个案例?

c - 为什么它给我错误“格式参数太多[-Wformat-extra-args]”

带矩阵的 Python 回归

r - 从相关矩阵值中查找行/列名称

来自多个文件的 Python txt 矩阵

c - C物理程序中的不规则行为

c - 为什么这段C代码会陷入无限循环?